diff --git a/packages/core/.gitignore b/packages/core/.gitignore index 421d908e61..57bf2e6855 100644 --- a/packages/core/.gitignore +++ b/packages/core/.gitignore @@ -40,3 +40,4 @@ flow-typed/npm/* .idea npm-debug.log.* +dist diff --git a/packages/core/dist/budibase-core.cjs.js b/packages/core/dist/budibase-core.cjs.js deleted file mode 100644 index ad7e491df9..0000000000 --- a/packages/core/dist/budibase-core.cjs.js +++ /dev/null @@ -1,8297 +0,0 @@ -'use strict'; - -Object.defineProperty(exports, '__esModule', { value: true }); - -function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; } - -var fp = require('lodash/fp'); -var shortid = require('shortid'); -var _ = require('lodash'); -var ___default = _interopDefault(_); -var compilerUtil = require('@nx-js/compiler-util'); -var lunr = _interopDefault(require('lunr')); -var safeBuffer = require('safe-buffer'); - -const commonPlus = extra => fp.union(['onBegin', 'onComplete', 'onError'])(extra); - -const common = () => commonPlus([]); - -const _events = { - recordApi: { - save: commonPlus([ - 'onInvalid', - 'onRecordUpdated', - 'onRecordCreated']), - delete: common(), - getContext: common(), - getNew: common(), - load: common(), - validate: common(), - uploadFile: common(), - downloadFile: common(), - }, - indexApi: { - buildIndex: common(), - listItems: common(), - delete: common(), - aggregates: common(), - }, - collectionApi: { - getAllowedRecordTypes: common(), - initialise: common(), - delete: common(), - }, - authApi: { - authenticate: common(), - authenticateTemporaryAccess: common(), - createTemporaryAccess: common(), - createUser: common(), - enableUser: common(), - disableUser: common(), - loadAccessLevels: common(), - getNewAccessLevel: common(), - getNewUser: common(), - getNewUserAuth: common(), - getUsers: common(), - saveAccessLevels: common(), - isAuthorized: common(), - changeMyPassword: common(), - setPasswordFromTemporaryCode: common(), - scorePassword: common(), - isValidPassword: common(), - validateUser: common(), - validateAccessLevels: common(), - setUserAccessLevels: common(), - }, - templateApi: { - saveApplicationHierarchy: common(), - saveActionsAndTriggers: common(), - }, - actionsApi: { - execute: common(), - }, -}; - -const _eventsList = []; - -const makeEvent = (area, method, name) => `${area}:${method}:${name}`; - -for (const areaKey in _events) { - for (const methodKey in _events[areaKey]) { - _events[areaKey][methodKey] = fp.reduce((obj, s) => { - obj[s] = makeEvent(areaKey, methodKey, s); - return obj; - }, - {})(_events[areaKey][methodKey]); - } -} - - -for (const areaKey in _events) { - for (const methodKey in _events[areaKey]) { - for (const name in _events[areaKey][methodKey]) { - _eventsList.push( - _events[areaKey][methodKey][name], - ); - } - } -} - - -const events = _events; - -const eventsList = _eventsList; - -class BadRequestError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 400; - } -} - -class UnauthorisedError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 401; - } -} - -class ForbiddenError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 403; - } -} - -class NotFoundError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 404; - } -} - -const apiWrapper = async (app, eventNamespace, isAuthorized, eventContext, func, ...params) => { - pushCallStack(app, eventNamespace); - - if (!isAuthorized(app)) { - handleNotAuthorized(app, eventContext, eventNamespace); - return; - } - - const startDate = Date.now(); - const elapsed = () => (Date.now() - startDate); - - try { - await app.publish( - eventNamespace.onBegin, - eventContext, - ); - - const result = await func(...params); - - await publishComplete(app, eventContext, eventNamespace, elapsed, result); - return result; - } catch (error) { - await publishError(app, eventContext, eventNamespace, elapsed, error); - throw error; - } -}; - -const apiWrapperSync = (app, eventNamespace, isAuthorized, eventContext, func, ...params) => { - pushCallStack(app, eventNamespace); - - if (!isAuthorized(app)) { - handleNotAuthorized(app, eventContext, eventNamespace); - return; - } - - const startDate = Date.now(); - const elapsed = () => (Date.now() - startDate); - - try { - app.publish( - eventNamespace.onBegin, - eventContext, - ); - - const result = func(...params); - - publishComplete(app, eventContext, eventNamespace, elapsed, result); - return result; - } catch (error) { - publishError(app, eventContext, eventNamespace, elapsed, error); - throw error; - } -}; - -const handleNotAuthorized = (app, eventContext, eventNamespace) => { - const err = new UnauthorisedError(`Unauthorized: ${eventNamespace}`); - publishError(app, eventContext, eventNamespace, () => 0, err); - throw err; -}; - -const pushCallStack = (app, eventNamespace, seedCallId) => { - const callId = shortid.generate(); - - const createCallStack = () => ({ - seedCallId: !fp.isUndefined(seedCallId) - ? seedCallId - : callId, - threadCallId: callId, - stack: [], - }); - - if (fp.isUndefined(app.calls)) { - app.calls = createCallStack(); - } - - app.calls.stack.push({ - namespace: eventNamespace, - callId, - }); -}; - -const popCallStack = (app) => { - app.calls.stack.pop(); - if (app.calls.stack.length === 0) { - delete app.calls; - } -}; - -const publishError = async (app, eventContext, eventNamespace, elapsed, err) => { - const ctx = fp.cloneDeep(eventContext); - ctx.error = err; - ctx.elapsed = elapsed(); - await app.publish( - eventNamespace.onError, - ctx, - ); - popCallStack(app); -}; - -const publishComplete = async (app, eventContext, eventNamespace, elapsed, result) => { - const endcontext = fp.cloneDeep(eventContext); - endcontext.result = result; - endcontext.elapsed = elapsed(); - await app.publish( - eventNamespace.onComplete, - endcontext, - ); - popCallStack(app); - return result; -}; - -const lockOverlapMilliseconds = 10; - -const getLock = async (app, lockFile, timeoutMilliseconds, maxLockRetries, retryCount = 0) => { - try { - const timeout = (await app.getEpochTime()) - + timeoutMilliseconds; - - const lock = { - timeout, - key: lockFile, - totalTimeout: timeoutMilliseconds, - }; - - await app.datastore.createFile( - lockFile, - getLockFileContent( - lock.totalTimeout, - lock.timeout, - ), - ); - - return lock; - } catch (e) { - if (retryCount == maxLockRetries) { return NO_LOCK; } - - const lock = parseLockFileContent( - lockFile, - await app.datastore.loadFile(lockFile), - ); - - const currentEpochTime = await app.getEpochTime(); - - if (currentEpochTime < lock.timeout) { - return NO_LOCK; - } - - try { - await app.datastore.deleteFile(lockFile); - } catch (_) { - //empty - } - - await sleepForRetry(); - - return await getLock( - app, lockFile, timeoutMilliseconds, - maxLockRetries, retryCount + 1, - ); - } -}; - -const getLockFileContent = (totalTimeout, epochTime) => `${totalTimeout}:${epochTime.toString()}`; - -const parseLockFileContent = (key, content) => $(content, [ - fp.split(':'), - parts => ({ - totalTimeout: new Number(parts[0]), - timeout: new Number(parts[1]), - key, - }), -]); - -const releaseLock = async (app, lock) => { - const currentEpochTime = await app.getEpochTime(); - // only release if not timedout - if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) { - try { - await app.datastore.deleteFile(lock.key); - } catch (_) { - //empty - } - } -}; - -const NO_LOCK = 'no lock'; -const isNolock = id => id === NO_LOCK; - -const sleepForRetry = () => new Promise(resolve => setTimeout(resolve, lockOverlapMilliseconds)); - -// this is the combinator function -const $$ = (...funcs) => arg => _.flow(funcs)(arg); - -// this is the pipe function -const $ = (arg, funcs) => $$(...funcs)(arg); - -const keySep = '/'; -const trimKeySep = str => _.trim(str, keySep); -const splitByKeySep = str => fp.split(keySep)(str); -const safeKey = key => _.replace(`${keySep}${trimKeySep(key)}`, `${keySep}${keySep}`, keySep); -const joinKey = (...strs) => { - const paramsOrArray = strs.length === 1 & fp.isArray(strs[0]) - ? strs[0] : strs; - return $(paramsOrArray, [ - fp.filter(s => !fp.isUndefined(s) - && !fp.isNull(s) - && s.toString().length > 0), - fp.join(keySep), - safeKey - ]); -}; -const splitKey = $$(trimKeySep, splitByKeySep); -const getDirFomKey = $$(splitKey, _.dropRight, p => joinKey(...p)); -const getFileFromKey = $$(splitKey, _.takeRight, _.head); - -const configFolder = `${keySep}.config`; -const fieldDefinitions = joinKey(configFolder, 'fields.json'); -const templateDefinitions = joinKey(configFolder, 'templates.json'); -const appDefinitionFile = joinKey(configFolder, 'appDefinition.json'); -const dirIndex = folderPath => joinKey(configFolder, 'dir', ...splitKey(folderPath), 'dir.idx'); -const getIndexKeyFromFileKey = $$(getDirFomKey, dirIndex); - -const ifExists = (val, exists, notExists) => (fp.isUndefined(val) - ? fp.isUndefined(notExists) ? (() => { })() : notExists() - : exists()); - -const getOrDefault = (val, defaultVal) => ifExists(val, () => val, () => defaultVal); - -const not = func => val => !func(val); -const isDefined = not(fp.isUndefined); -const isNonNull = not(fp.isNull); -const isNotNaN = not(fp.isNaN); - -const allTrue = (...funcArgs) => val => fp.reduce( - (result, conditionFunc) => (fp.isNull(result) || result == true) && conditionFunc(val), - null)(funcArgs); - -const anyTrue = (...funcArgs) => val => fp.reduce( - (result, conditionFunc) => result == true || conditionFunc(val), - null)(funcArgs); - -const insensitiveEquals = (str1, str2) => str1.trim().toLowerCase() === str2.trim().toLowerCase(); - -const isSomething = allTrue(isDefined, isNonNull, isNotNaN); -const isNothing = not(isSomething); -const isNothingOrEmpty = v => isNothing(v) || fp.isEmpty(v); -const somethingOrGetDefault = getDefaultFunc => val => (isSomething(val) ? val : getDefaultFunc()); -const somethingOrDefault = (val, defaultVal) => somethingOrGetDefault(fp.constant(defaultVal))(val); - -const mapIfSomethingOrDefault = (mapFunc, defaultVal) => val => (isSomething(val) ? mapFunc(val) : defaultVal); - -const mapIfSomethingOrBlank = mapFunc => mapIfSomethingOrDefault(mapFunc, ''); - -const none = predicate => collection => !fp.some(predicate)(collection); - -const all = predicate => collection => none(v => !predicate(v))(collection); - -const isNotEmpty = ob => !fp.isEmpty(ob); -const isNonEmptyArray = allTrue(fp.isArray, isNotEmpty); -const isNonEmptyString = allTrue(fp.isString, isNotEmpty); -const tryOr = failFunc => (func, ...args) => { - try { - return func.apply(null, ...args); - } catch (_) { - return failFunc(); - } -}; - -const tryAwaitOr = failFunc => async (func, ...args) => { - try { - return await func.apply(null, ...args); - } catch (_) { - return await failFunc(); - } -}; - -const defineError = (func, errorPrefix) => { - try { - return func(); - } catch (err) { - err.message = `${errorPrefix} : ${err.message}`; - throw err; - } -}; - -const tryOrIgnore = tryOr(() => { }); -const tryAwaitOrIgnore = tryAwaitOr(async () => { }); -const causesException = (func) => { - try { - func(); - return false; - } catch (e) { - return true; - } -}; - -const executesWithoutException = func => !causesException(func); - -const handleErrorWith = returnValInError => tryOr(fp.constant(returnValInError)); - -const handleErrorWithUndefined = handleErrorWith(undefined); - -const switchCase = (...cases) => (value) => { - const nextCase = () => _.head(cases)[0](value); - const nextResult = () => _.head(cases)[1](value); - - if (fp.isEmpty(cases)) return; // undefined - if (nextCase() === true) return nextResult(); - return switchCase(..._.tail(cases))(value); -}; - -const isValue = val1 => val2 => (val1 === val2); -const isOneOf = (...vals) => val => fp.includes(val)(vals); -const defaultCase = fp.constant(true); -const memberMatches = (member, match) => obj => match(obj[member]); - - -const StartsWith = searchFor => searchIn => _.startsWith(searchIn, searchFor); - -const contains = val => array => (_.findIndex(array, v => v === val) > -1); - -const getHashCode = (s) => { - let hash = 0; let i; let char; let - l; - if (s.length == 0) return hash; - for (i = 0, l = s.length; i < l; i++) { - char = s.charCodeAt(i); - hash = ((hash << 5) - hash) + char; - hash |= 0; // Convert to 32bit integer - } - - // converting to string, but dont want a "-" prefixed - if (hash < 0) { return `n${(hash * -1).toString()}`; } - return hash.toString(); -}; - -// thanks to https://blog.grossman.io/how-to-write-async-await-without-try-catch-blocks-in-javascript/ -const awEx = async (promise) => { - try { - const result = await promise; - return [undefined, result]; - } catch (error) { - return [error, undefined]; - } -}; - -const isSafeInteger = n => fp.isInteger(n) - && n <= Number.MAX_SAFE_INTEGER - && n >= 0 - Number.MAX_SAFE_INTEGER; - -const toDateOrNull = s => (fp.isNull(s) ? null - : fp.isDate(s) ? s : new Date(s)); -const toBoolOrNull = s => (fp.isNull(s) ? null - : s === 'true' || s === true); -const toNumberOrNull = s => (fp.isNull(s) ? null - : fp.toNumber(s)); - -const isArrayOfString = opts => fp.isArray(opts) && all(fp.isString)(opts); - -const pushAll = (target, items) => { - for(let i of items) target.push(i); -}; - -const pause = async duration => new Promise(res => setTimeout(res, duration)); - -const retry = async (fn, retries, delay, ...args) => { - try { - return await fn(...args); - } catch (err) { - if (retries > 1) { - return await pause(delay).then(async () => await retry(fn, (retries - 1), delay, ...args)); - } - throw err; - } -}; - -var index = { - ifExists, - getOrDefault, - isDefined, - isNonNull, - isNotNaN, - allTrue, - isSomething, - mapIfSomethingOrDefault, - mapIfSomethingOrBlank, - configFolder, - fieldDefinitions, - isNothing, - not, - switchCase, - defaultCase, - StartsWith, - contains, - templateDefinitions, - handleErrorWith, - handleErrorWithUndefined, - tryOr, - tryOrIgnore, - tryAwaitOr, - tryAwaitOrIgnore, - dirIndex, - keySep, - $, - $$, - getDirFomKey, - getFileFromKey, - splitKey, - somethingOrDefault, - getIndexKeyFromFileKey, - joinKey, - somethingOrGetDefault, - appDefinitionFile, - isValue, - all, - isOneOf, - memberMatches, - defineError, - anyTrue, - isNonEmptyArray, - causesException, - executesWithoutException, - none, - getHashCode, - awEx, - apiWrapper, - events, - eventsList, - isNothingOrEmpty, - isSafeInteger, - toNumber: fp.toNumber, - toDate: toDateOrNull, - toBool: toBoolOrNull, - isArrayOfString, - getLock, - NO_LOCK, - isNolock, - insensitiveEquals, - pause, - retry, - pushAll -}; - -const stringNotEmpty = s => isSomething(s) && s.trim().length > 0; - -const makerule = (field, error, isValid) => ({ field, error, isValid }); - -const validationError = (rule, item) => ({ ...rule, item }); - -const applyRuleSet = ruleSet => itemToValidate => $(ruleSet, [ - fp.map(applyRule(itemToValidate)), - fp.filter(isSomething), -]); - -const applyRule = itemTovalidate => rule => (rule.isValid(itemTovalidate) - ? null - : validationError(rule, itemTovalidate)); - -const filterEval = 'FILTER_EVALUATE'; -const filterCompile = 'FILTER_COMPILE'; -const mapEval = 'MAP_EVALUATE'; -const mapCompile = 'MAP_COMPILE'; - - -const getEvaluateResult = () => ({ - isError: false, - passedFilter: true, - result: null, -}); - -const compileFilter = index => compilerUtil.compileExpression(index.filter); - -const compileMap = index => compilerUtil.compileCode(index.map); - -const passesFilter = (record, index) => { - const context = { record }; - if (!index.filter) return true; - - const compiledFilter = defineError( - () => compileFilter(index), - filterCompile, - ); - - return defineError( - () => compiledFilter(context), - filterEval, - ); -}; - -const mapRecord = (record, index) => { - const recordClone = fp.cloneDeep(record); - const context = { record: recordClone }; - - const map = index.map ? index.map : 'return {...record};'; - - const compiledMap = defineError( - () => compilerUtil.compileCode(map), - mapCompile, - ); - - const mapped = defineError( - () => compiledMap(context), - mapEval, - ); - - const mappedKeys = fp.keys(mapped); - for (let i = 0; i < mappedKeys.length; i++) { - const key = mappedKeys[i]; - mapped[key] = fp.isUndefined(mapped[key]) ? null : mapped[key]; - if (fp.isFunction(mapped[key])) { - delete mapped[key]; - } - } - - mapped.key = record.key; - mapped.sortKey = index.getSortKey - ? compilerUtil.compileCode(index.getSortKey)(context) - : record.id; - - return mapped; -}; - -const evaluate = record => (index) => { - const result = getEvaluateResult(); - - try { - result.passedFilter = passesFilter(record, index); - } catch (err) { - result.isError = true; - result.passedFilter = false; - result.result = err.message; - } - - if (!result.passedFilter) return result; - - try { - result.result = mapRecord(record, index); - } catch (err) { - result.isError = true; - result.result = err.message; - } - - return result; -}; - -const indexTypes = { reference: 'reference', ancestor: 'ancestor' }; - -const indexRuleSet = [ - makerule('map', 'index has no map function', - index => isNonEmptyString(index.map)), - makerule('map', "index's map function does not compile", - index => !isNonEmptyString(index.map) - || executesWithoutException(() => compileMap(index))), - makerule('filter', "index's filter function does not compile", - index => !isNonEmptyString(index.filter) - || executesWithoutException(() => compileFilter(index))), - makerule('name', 'must declare a name for index', - index => isNonEmptyString(index.name)), - makerule('name', 'there is a duplicate named index on this node', - index => fp.isEmpty(index.name) - || fp.countBy('name')(index.parent().indexes)[index.name] === 1), - makerule('indexType', 'reference index may only exist on a record node', - index => isRecord(index.parent()) - || index.indexType !== indexTypes.reference), - makerule('indexType', `index type must be one of: ${fp.join(', ')(fp.keys(indexTypes))}`, - index => fp.includes(index.indexType)(fp.keys(indexTypes))), -]; - -const getFlattenedHierarchy = (appHierarchy, useCached = true) => { - if (isSomething(appHierarchy.getFlattenedHierarchy) && useCached) { return appHierarchy.getFlattenedHierarchy(); } - - const flattenHierarchy = (currentNode, flattened) => { - flattened.push(currentNode); - if ((!currentNode.children - || currentNode.children.length === 0) - && (!currentNode.indexes - || currentNode.indexes.length === 0) - && (!currentNode.aggregateGroups - || currentNode.aggregateGroups.length === 0)) { - return flattened; - } - - const unionIfAny = l2 => l1 => fp.union(l1)(!l2 ? [] : l2); - - const children = $([], [ - unionIfAny(currentNode.children), - unionIfAny(currentNode.indexes), - unionIfAny(currentNode.aggregateGroups), - ]); - - for (const child of children) { - flattenHierarchy(child, flattened); - } - return flattened; - }; - - appHierarchy.getFlattenedHierarchy = () => flattenHierarchy(appHierarchy, []); - return appHierarchy.getFlattenedHierarchy(); -}; - -const getLastPartInKey = key => fp.last(splitKey(key)); - -const getNodesInPath = appHierarchy => key => $(appHierarchy, [ - getFlattenedHierarchy, - fp.filter(n => new RegExp(`${n.pathRegx()}`).test(key)), -]); - -const getExactNodeForKey = appHierarchy => key => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => new RegExp(`${n.pathRegx()}$`).test(key)), -]); - -const getNodeForCollectionPath = appHierarchy => collectionKey => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => (isCollectionRecord(n) - && new RegExp(`${n.collectionPathRegx()}$`).test(collectionKey))), -]); - -const hasMatchingAncestor = ancestorPredicate => decendantNode => switchCase( - - [node => isNothing(node.parent()), - fp.constant(false)], - - [node => ancestorPredicate(node.parent()), - fp.constant(true)], - - [defaultCase, - node => hasMatchingAncestor(ancestorPredicate)(node.parent())], - -)(decendantNode); - -const getNode = (appHierarchy, nodeKey) => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => n.nodeKey() === nodeKey - || (isCollectionRecord(n) - && n.collectionNodeKey() === nodeKey)), -]); - -const getCollectionNode = (appHierarchy, nodeKey) => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => (isCollectionRecord(n) - && n.collectionNodeKey() === nodeKey)), -]); - -const getNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => { - const nodeByKey = getExactNodeForKey(appHierarchy)(keyOrNodeKey); - return isNothing(nodeByKey) - ? getNode(appHierarchy, keyOrNodeKey) - : nodeByKey; -}; - -const getCollectionNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => { - const nodeByKey = getNodeForCollectionPath(appHierarchy)(keyOrNodeKey); - return isNothing(nodeByKey) - ? getCollectionNode(appHierarchy, keyOrNodeKey) - : nodeByKey; -}; - -const isNode = (appHierarchy, key) => isSomething(getExactNodeForKey(appHierarchy)(key)); - -const getActualKeyOfParent = (parentNodeKey, actualChildKey) => - $(actualChildKey, [ - splitKey, - fp.take(splitKey(parentNodeKey).length), - ks => joinKey(...ks), - ]); - -const getParentKey = (key) => { - return $(key, [ - splitKey, - fp.take(splitKey(key).length - 1), - joinKey, - ]); -}; - -const isKeyAncestorOf = ancestorKey => decendantNode => hasMatchingAncestor(p => p.nodeKey() === ancestorKey)(decendantNode); - -const hasNoMatchingAncestors = parentPredicate => node => !hasMatchingAncestor(parentPredicate)(node); - -const findField = (recordNode, fieldName) => fp.find(f => f.name == fieldName)(recordNode.fields); - -const isAncestor = decendant => ancestor => isKeyAncestorOf(ancestor.nodeKey())(decendant); - -const isDecendant = ancestor => decendant => isAncestor(decendant)(ancestor); - -const getRecordNodeId = recordKey => $(recordKey, [ - splitKey, - fp.last, - getRecordNodeIdFromId, -]); - -const getRecordNodeIdFromId = recordId => $(recordId, [fp.split('-'), fp.first, parseInt]); - -const getRecordNodeById = (hierarchy, recordId) => $(hierarchy, [ - getFlattenedHierarchy, - fp.find(n => isRecord(n) - && n.nodeId === getRecordNodeIdFromId(recordId)), -]); - -const recordNodeIdIsAllowed = indexNode => nodeId => indexNode.allowedRecordNodeIds.length === 0 - || fp.includes(nodeId)(indexNode.allowedRecordNodeIds); - -const recordNodeIsAllowed = indexNode => recordNode => recordNodeIdIsAllowed(indexNode)(recordNode.nodeId); - -const getAllowedRecordNodesForIndex = (appHierarchy, indexNode) => { - const recordNodes = $(appHierarchy, [ - getFlattenedHierarchy, - fp.filter(isRecord), - ]); - - if (isGlobalIndex(indexNode)) { - return $(recordNodes, [ - fp.filter(recordNodeIsAllowed(indexNode)), - ]); - } - - if (isAncestorIndex(indexNode)) { - return $(recordNodes, [ - fp.filter(isDecendant(indexNode.parent())), - fp.filter(recordNodeIsAllowed(indexNode)), - ]); - } - - if (isReferenceIndex(indexNode)) { - return $(recordNodes, [ - fp.filter(n => fp.some(fieldReversesReferenceToIndex(indexNode))(n.fields)), - ]); - } -}; - -const getNodeFromNodeKeyHash = hierarchy => hash => $(hierarchy, [ - getFlattenedHierarchy, - fp.find(n => getHashCode(n.nodeKey()) === hash), -]); - -const isRecord = node => isSomething(node) && node.type === 'record'; -const isSingleRecord = node => isRecord(node) && node.isSingle; -const isCollectionRecord = node => isRecord(node) && !node.isSingle; -const isIndex = node => isSomething(node) && node.type === 'index'; -const isaggregateGroup = node => isSomething(node) && node.type === 'aggregateGroup'; -const isShardedIndex = node => isIndex(node) && isNonEmptyString(node.getShardName); -const isRoot = node => isSomething(node) && node.isRoot(); -const isDecendantOfARecord = hasMatchingAncestor(isRecord); -const isGlobalIndex = node => isIndex(node) && isRoot(node.parent()); -const isReferenceIndex = node => isIndex(node) && node.indexType === indexTypes.reference; -const isAncestorIndex = node => isIndex(node) && node.indexType === indexTypes.ancestor; - -const fieldReversesReferenceToNode = node => field => field.type === 'reference' - && fp.intersection(field.typeOptions.reverseIndexNodeKeys)(fp.map(i => i.nodeKey())(node.indexes)) - .length > 0; - -const fieldReversesReferenceToIndex = indexNode => field => field.type === 'reference' - && fp.intersection(field.typeOptions.reverseIndexNodeKeys)([indexNode.nodeKey()]) - .length > 0; - -var hierarchy = { - getLastPartInKey, - getNodesInPath, - getExactNodeForKey, - hasMatchingAncestor, - getNode, - getNodeByKeyOrNodeKey, - isNode, - getActualKeyOfParent, - getParentKey, - isKeyAncestorOf, - hasNoMatchingAncestors, - findField, - isAncestor, - isDecendant, - getRecordNodeId, - getRecordNodeIdFromId, - getRecordNodeById, - recordNodeIdIsAllowed, - recordNodeIsAllowed, - getAllowedRecordNodesForIndex, - getNodeFromNodeKeyHash, - isRecord, - isCollectionRecord, - isIndex, - isaggregateGroup, - isShardedIndex, - isRoot, - isDecendantOfARecord, - isGlobalIndex, - isReferenceIndex, - isAncestorIndex, - fieldReversesReferenceToNode, - fieldReversesReferenceToIndex, - getFlattenedHierarchy, -}; - -const getSafeFieldParser = (tryParse, defaultValueFunctions) => (field, record) => { - if (fp.has(field.name)(record)) { - return getSafeValueParser(tryParse, defaultValueFunctions)(record[field.name]); - } - return defaultValueFunctions[field.getUndefinedValue](); -}; - -const getSafeValueParser = (tryParse, defaultValueFunctions) => (value) => { - const parsed = tryParse(value); - if (parsed.success) { - return parsed.value; - } - return defaultValueFunctions.default(); -}; - -const getNewValue = (tryParse, defaultValueFunctions) => (field) => { - const getInitialValue = fp.isUndefined(field) || fp.isUndefined(field.getInitialValue) - ? 'default' - : field.getInitialValue; - - return fp.has(getInitialValue)(defaultValueFunctions) - ? defaultValueFunctions[getInitialValue]() - : getSafeValueParser(tryParse, defaultValueFunctions)(getInitialValue); -}; - -const typeFunctions = specificFunctions => _.merge({ - value: fp.constant, - null: fp.constant(null), -}, specificFunctions); - -const validateTypeConstraints = validationRules => async (field, record, context) => { - const fieldValue = record[field.name]; - const validateRule = async r => (!await r.isValid(fieldValue, field.typeOptions, context) - ? r.getMessage(fieldValue, field.typeOptions) - : ''); - - const errors = []; - for (const r of validationRules) { - const err = await validateRule(r); - if (isNotEmpty(err)) errors.push(err); - } - - return errors; -}; - -const getDefaultOptions = fp.mapValues(v => v.defaultValue); - -const makerule$1 = (isValid, getMessage) => ({ isValid, getMessage }); -const parsedFailed = val => ({ success: false, value: val }); -const parsedSuccess = val => ({ success: true, value: val }); -const getDefaultExport = (name, tryParse, functions, options, validationRules, sampleValue, stringify) => ({ - getNew: getNewValue(tryParse, functions), - safeParseField: getSafeFieldParser(tryParse, functions), - safeParseValue: getSafeValueParser(tryParse, functions), - tryParse, - name, - getDefaultOptions: () => getDefaultOptions(fp.cloneDeep(options)), - optionDefinitions: options, - validateTypeConstraints: validateTypeConstraints(validationRules), - sampleValue, - stringify: val => (val === null || val === undefined - ? '' : stringify(val)), - getDefaultValue: functions.default, -}); - -const stringFunctions = typeFunctions({ - default: fp.constant(null), -}); - -const stringTryParse = switchCase( - [fp.isString, parsedSuccess], - [fp.isNull, parsedSuccess], - [defaultCase, v => parsedSuccess(v.toString())], -); - -const options = { - maxLength: { - defaultValue: null, - isValid: n => n === null || isSafeInteger(n) && n > 0, - requirementDescription: 'max length must be null (no limit) or a greater than zero integer', - parse: toNumberOrNull, - }, - values: { - defaultValue: null, - isValid: v => v === null || (isArrayOfString(v) && v.length > 0 && v.length < 10000), - requirementDescription: "'values' must be null (no values) or an arry of at least one string", - parse: s => s, - }, - allowDeclaredValuesOnly: { - defaultValue: false, - isValid: fp.isBoolean, - requirementDescription: 'allowDeclaredValuesOnly must be true or false', - parse: toBoolOrNull, - }, -}; - -const typeConstraints = [ - makerule$1(async (val, opts) => val === null || opts.maxLength === null || val.length <= opts.maxLength, - (val, opts) => `value exceeds maximum length of ${opts.maxLength}`), - makerule$1(async (val, opts) => val === null - || opts.allowDeclaredValuesOnly === false - || fp.includes(val)(opts.values), - (val) => `"${val}" does not exist in the list of allowed values`), -]; - -var string = getDefaultExport( - 'string', - stringTryParse, - stringFunctions, - options, - typeConstraints, - 'abcde', - str => str, -); - -const boolFunctions = typeFunctions({ - default: fp.constant(null), -}); - -const boolTryParse = switchCase( - [fp.isBoolean, parsedSuccess], - [fp.isNull, parsedSuccess], - [isOneOf('true', '1', 'yes', 'on'), () => parsedSuccess(true)], - [isOneOf('false', '0', 'no', 'off'), () => parsedSuccess(false)], - [defaultCase, parsedFailed], -); - -const options$1 = { - allowNulls: { - defaultValue: true, - isValid: fp.isBoolean, - requirementDescription: 'must be a true or false', - parse: toBoolOrNull, - }, -}; - -const typeConstraints$1 = [ - makerule$1(async (val, opts) => opts.allowNulls === true || val !== null, - () => 'field cannot be null'), -]; - -var bool = getDefaultExport( - 'bool', boolTryParse, boolFunctions, - options$1, typeConstraints$1, true, JSON.stringify, -); - -const numberFunctions = typeFunctions({ - default: fp.constant(null), -}); - -const parseStringtoNumberOrNull = (s) => { - const num = Number(s); - return isNaN(num) ? parsedFailed(s) : parsedSuccess(num); -}; - -const numberTryParse = switchCase( - [fp.isNumber, parsedSuccess], - [fp.isString, parseStringtoNumberOrNull], - [fp.isNull, parsedSuccess], - [defaultCase, parsedFailed], -); - -const options$2 = { - maxValue: { - defaultValue: Number.MAX_SAFE_INTEGER, - isValid: isSafeInteger, - requirementDescription: 'must be a valid integer', - parse: toNumberOrNull, - }, - minValue: { - defaultValue: 0 - Number.MAX_SAFE_INTEGER, - isValid: isSafeInteger, - requirementDescription: 'must be a valid integer', - parse: toNumberOrNull, - }, - decimalPlaces: { - defaultValue: 0, - isValid: n => isSafeInteger(n) && n >= 0, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, -}; - -const getDecimalPlaces = (val) => { - const splitDecimal = val.toString().split('.'); - if (splitDecimal.length === 1) return 0; - return splitDecimal[1].length; -}; - -const typeConstraints$2 = [ - makerule$1(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue, - (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`), - makerule$1(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue, - (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`), - makerule$1(async (val, opts) => val === null || opts.decimalPlaces >= getDecimalPlaces(val), - (val, opts) => `value (${val.toString()}) must have ${opts.decimalPlaces} decimal places or less`), -]; - -var number = getDefaultExport( - 'number', - numberTryParse, - numberFunctions, - options$2, - typeConstraints$2, - 1, - num => num.toString(), -); - -const dateFunctions = typeFunctions({ - default: fp.constant(null), - now: () => new Date(), -}); - -const isValidDate = d => d instanceof Date && !isNaN(d); - -const parseStringToDate = s => switchCase( - [isValidDate, parsedSuccess], - [defaultCase, parsedFailed], -)(new Date(s)); - - -const dateTryParse = switchCase( - [fp.isDate, parsedSuccess], - [fp.isString, parseStringToDate], - [fp.isNull, parsedSuccess], - [defaultCase, parsedFailed], -); - -const options$3 = { - maxValue: { - defaultValue: new Date(32503680000000), - isValid: fp.isDate, - requirementDescription: 'must be a valid date', - parse: toDateOrNull, - }, - minValue: { - defaultValue: new Date(-8520336000000), - isValid: fp.isDate, - requirementDescription: 'must be a valid date', - parse: toDateOrNull, - }, -}; - -const typeConstraints$3 = [ - makerule$1(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue, - (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`), - makerule$1(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue, - (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`), -]; - -var datetime = getDefaultExport( - 'datetime', - dateTryParse, - dateFunctions, - options$3, - typeConstraints$3, - new Date(1984, 4, 1), - date => JSON.stringify(date).replace(new RegExp('"', 'g'), ''), -); - -const arrayFunctions = () => typeFunctions({ - default: fp.constant([]), -}); - -const mapToParsedArrary = type => $$( - fp.map(i => type.safeParseValue(i)), - parsedSuccess, -); - -const arrayTryParse = type => switchCase( - [fp.isArray, mapToParsedArrary(type)], - [defaultCase, parsedFailed], -); - -const typeName = type => `array<${type}>`; - - -const options$4 = { - maxLength: { - defaultValue: 10000, - isValid: isSafeInteger, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, - minLength: { - defaultValue: 0, - isValid: n => isSafeInteger(n) && n >= 0, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, -}; - -const typeConstraints$4 = [ - makerule$1(async (val, opts) => val === null || val.length >= opts.minLength, - (val, opts) => `must choose ${opts.minLength} or more options`), - makerule$1(async (val, opts) => val === null || val.length <= opts.maxLength, - (val, opts) => `cannot choose more than ${opts.maxLength} options`), -]; - -var array = type => getDefaultExport( - typeName(type.name), - arrayTryParse(type), - arrayFunctions(), - options$4, - typeConstraints$4, - [type.sampleValue], - JSON.stringify, -); - -const referenceNothing = () => ({ key: '' }); - -const referenceFunctions = typeFunctions({ - default: referenceNothing, -}); - -const hasStringValue = (ob, path) => fp.has(path)(ob) - && fp.isString(ob[path]); - -const isObjectWithKey = v => fp.isObjectLike(v) - && hasStringValue(v, 'key'); - -const tryParseFromString = s => { - - try { - const asObj = JSON.parse(s); - if(isObjectWithKey) { - return parsedSuccess(asObj); - } - } - catch(_) { - // EMPTY - } - - return parsedFailed(s); -}; - -const referenceTryParse = v => switchCase( - [isObjectWithKey, parsedSuccess], - [fp.isString, tryParseFromString], - [fp.isNull, () => parsedSuccess(referenceNothing())], - [defaultCase, parsedFailed], -)(v); - -const options$5 = { - indexNodeKey: { - defaultValue: null, - isValid: isNonEmptyString, - requirementDescription: 'must be a non-empty string', - parse: s => s, - }, - displayValue: { - defaultValue: '', - isValid: isNonEmptyString, - requirementDescription: 'must be a non-empty string', - parse: s => s, - }, - reverseIndexNodeKeys: { - defaultValue: null, - isValid: v => isArrayOfString(v) && v.length > 0, - requirementDescription: 'must be a non-empty array of strings', - parse: s => s, - }, -}; - -const isEmptyString = s => fp.isString(s) && fp.isEmpty(s); - -const ensureReferenceExists = async (val, opts, context) => isEmptyString(val.key) - || await context.referenceExists(opts, val.key); - -const typeConstraints$5 = [ - makerule$1( - ensureReferenceExists, - (val, opts) => `"${val[opts.displayValue]}" does not exist in options list (key: ${val.key})`, - ), -]; - -var reference = getDefaultExport( - 'reference', - referenceTryParse, - referenceFunctions, - options$5, - typeConstraints$5, - { key: 'key', value: 'value' }, - JSON.stringify, -); - -const illegalCharacters = '*?\\/:<>|\0\b\f\v'; - -const isLegalFilename = (filePath) => { - const fn = fileName(filePath); - return fn.length <= 255 - && fp.intersection(fn.split(''))(illegalCharacters.split('')).length === 0 - && none(f => f === '..')(splitKey(filePath)); -}; - -const fileNothing = () => ({ relativePath: '', size: 0 }); - -const fileFunctions = typeFunctions({ - default: fileNothing, -}); - -const fileTryParse = v => switchCase( - [isValidFile, parsedSuccess], - [fp.isNull, () => parsedSuccess(fileNothing())], - [defaultCase, parsedFailed], -)(v); - -const fileName = filePath => $(filePath, [ - splitKey, - fp.last, -]); - -const isValidFile = f => !fp.isNull(f) - && fp.has('relativePath')(f) && fp.has('size')(f) - && fp.isNumber(f.size) - && fp.isString(f.relativePath) - && isLegalFilename(f.relativePath); - -const options$6 = {}; - -const typeConstraints$6 = []; - -var file = getDefaultExport( - 'file', - fileTryParse, - fileFunctions, - options$6, - typeConstraints$6, - { relativePath: 'some_file.jpg', size: 1000 }, - JSON.stringify, -); - -const allTypes = () => { - const basicTypes = { - string, number, datetime, bool, reference, file, - }; - - const arrays = $(basicTypes, [ - fp.keys, - fp.map((k) => { - const kvType = {}; - const concreteArray = array(basicTypes[k]); - kvType[concreteArray.name] = concreteArray; - return kvType; - }), - types => _.assign({}, ...types), - ]); - - return _.merge({}, basicTypes, arrays); -}; - - -const all$1 = allTypes(); - -const getType = (typeName) => { - if (!fp.has(typeName)(all$1)) throw new BadRequestError(`Do not recognise type ${typeName}`); - return all$1[typeName]; -}; - -const getSampleFieldValue = field => getType(field.type).sampleValue; - -const getNewFieldValue = field => getType(field.type).getNew(field); - -const safeParseField = (field, record) => getType(field.type).safeParseField(field, record); - -const validateFieldParse = (field, record) => (fp.has(field.name)(record) - ? getType(field.type).tryParse(record[field.name]) - : parsedSuccess(undefined)); // fields may be undefined by default - -const getDefaultOptions$1 = type => getType(type).getDefaultOptions(); - -const validateTypeConstraints$1 = async (field, record, context) => await getType(field.type).validateTypeConstraints(field, record, context); - -const detectType = (value) => { - if (fp.isString(value)) return string; - if (fp.isBoolean(value)) return bool; - if (fp.isNumber(value)) return number; - if (fp.isDate(value)) return datetime; - if (fp.isArray(value)) return array(detectType(value[0])); - if (fp.isObject(value) - && fp.has('key')(value) - && fp.has('value')(value)) return reference; - if (fp.isObject(value) - && fp.has('relativePath')(value) - && fp.has('size')(value)) return file; - - throw new BadRequestError(`cannot determine type: ${JSON.stringify(value)}`); -}; - -// 5 minutes -const tempCodeExpiryLength = 5 * 60 * 1000; - -const AUTH_FOLDER = '/.auth'; -const USERS_LIST_FILE = joinKey(AUTH_FOLDER, 'users.json'); -const userAuthFile = username => joinKey(AUTH_FOLDER, `auth_${username}.json`); -const USERS_LOCK_FILE = joinKey(AUTH_FOLDER, 'users_lock'); -const ACCESS_LEVELS_FILE = joinKey(AUTH_FOLDER, 'access_levels.json'); -const ACCESS_LEVELS_LOCK_FILE = joinKey(AUTH_FOLDER, 'access_levels_lock'); - -const permissionTypes = { - CREATE_RECORD: 'create record', - UPDATE_RECORD: 'update record', - READ_RECORD: 'read record', - DELETE_RECORD: 'delete record', - READ_INDEX: 'read index', - MANAGE_INDEX: 'manage index', - MANAGE_COLLECTION: 'manage collection', - WRITE_TEMPLATES: 'write templates', - CREATE_USER: 'create user', - SET_PASSWORD: 'set password', - CREATE_TEMPORARY_ACCESS: 'create temporary access', - ENABLE_DISABLE_USER: 'enable or disable user', - WRITE_ACCESS_LEVELS: 'write access levels', - LIST_USERS: 'list users', - LIST_ACCESS_LEVELS: 'list access levels', - EXECUTE_ACTION: 'execute action', - SET_USER_ACCESS_LEVELS: 'set user access levels', -}; - -const getUserByName = (users, name) => $(users, [ - fp.find(u => u.name.toLowerCase() === name.toLowerCase()), -]); - -const stripUserOfSensitiveStuff = (user) => { - const stripped = fp.clone(user); - delete stripped.tempCode; - return stripped; -}; - -const parseTemporaryCode = fullCode => $(fullCode, [ - fp.split(':'), - parts => ({ - id: parts[1], - code: parts[2], - }), -]); - -const isAuthorized = app => (permissionType, resourceKey) => apiWrapperSync( - app, - events.authApi.isAuthorized, - alwaysAuthorized, - { resourceKey, permissionType }, - _isAuthorized, app, permissionType, resourceKey, -); - -const _isAuthorized = (app, permissionType, resourceKey) => { - if (!app.user) { - return false; - } - - const validType = $(permissionTypes, [ - fp.values, - fp.includes(permissionType), - ]); - - if (!validType) { - return false; - } - - const permMatchesResource = (userperm) => { - const nodeKey = isNothing(resourceKey) - ? null - : isNode(app.hierarchy, resourceKey) - ? getNodeByKeyOrNodeKey( - app.hierarchy, resourceKey, - ).nodeKey() - : resourceKey; - - return (userperm.type === permissionType) - && ( - isNothing(resourceKey) - || nodeKey === userperm.nodeKey - ); - }; - - return $(app.user.permissions, [ - fp.some(permMatchesResource), - ]); -}; - -const nodePermission = type => ({ - add: (nodeKey, accessLevel) => accessLevel.permissions.push({ type, nodeKey }), - isAuthorized: resourceKey => app => isAuthorized(app)(type, resourceKey), - isNode: true, - get: nodeKey => ({ type, nodeKey }), -}); - -const staticPermission = type => ({ - add: accessLevel => accessLevel.permissions.push({ type }), - isAuthorized: app => isAuthorized(app)(type), - isNode: false, - get: () => ({ type }), -}); - -const createRecord = nodePermission(permissionTypes.CREATE_RECORD); - -const updateRecord = nodePermission(permissionTypes.UPDATE_RECORD); - -const deleteRecord = nodePermission(permissionTypes.DELETE_RECORD); - -const readRecord = nodePermission(permissionTypes.READ_RECORD); - -const writeTemplates = staticPermission(permissionTypes.WRITE_TEMPLATES); - -const createUser = staticPermission(permissionTypes.CREATE_USER); - -const setPassword = staticPermission(permissionTypes.SET_PASSWORD); - -const readIndex = nodePermission(permissionTypes.READ_INDEX); - -const manageIndex = staticPermission(permissionTypes.MANAGE_INDEX); - -const manageCollection = staticPermission(permissionTypes.MANAGE_COLLECTION); - -const createTemporaryAccess = staticPermission(permissionTypes.CREATE_TEMPORARY_ACCESS); - -const enableDisableUser = staticPermission(permissionTypes.ENABLE_DISABLE_USER); - -const writeAccessLevels = staticPermission(permissionTypes.WRITE_ACCESS_LEVELS); - -const listUsers = staticPermission(permissionTypes.LIST_USERS); - -const listAccessLevels = staticPermission(permissionTypes.LIST_ACCESS_LEVELS); - -const setUserAccessLevels = staticPermission(permissionTypes.SET_USER_ACCESS_LEVELS); - -const executeAction = nodePermission(permissionTypes.EXECUTE_ACTION); - -const alwaysAuthorized = () => true; - -const permission = { - createRecord, - updateRecord, - deleteRecord, - readRecord, - writeTemplates, - createUser, - setPassword, - readIndex, - createTemporaryAccess, - enableDisableUser, - writeAccessLevels, - listUsers, - listAccessLevels, - manageIndex, - manageCollection, - executeAction, - setUserAccessLevels, -}; - -const getNew = app => (collectionKey, recordTypeName) => { - const recordNode = getRecordNode(app, collectionKey); - collectionKey=safeKey(collectionKey); - return apiWrapperSync( - app, - events.recordApi.getNew, - permission.createRecord.isAuthorized(recordNode.nodeKey()), - { collectionKey, recordTypeName }, - _getNew, recordNode, collectionKey, - ); -}; - -const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey); - -const getRecordNode = (app, collectionKey) => { - collectionKey = safeKey(collectionKey); - return getNodeForCollectionPath(app.hierarchy)(collectionKey); -}; - -const getNewChild = app => (recordKey, collectionName, recordTypeName) => - getNew(app)(joinKey(recordKey, collectionName), recordTypeName); - -const constructRecord = (recordNode, getFieldValue, collectionKey) => { - const record = $(recordNode.fields, [ - fp.keyBy('name'), - fp.mapValues(getFieldValue), - ]); - - record.id = `${recordNode.nodeId}-${shortid.generate()}`; - record.key = isSingleRecord(recordNode) - ? joinKey(collectionKey, recordNode.name) - : joinKey(collectionKey, record.id); - record.isNew = true; - record.type = recordNode.name; - return record; -}; - -const allIdChars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_-'; - -// this should never be changed - ever -// - existing databases depend on the order of chars this string - -/** - * folderStructureArray should return an array like - * - [1] = all records fit into one folder - * - [2] = all records fite into 2 folders - * - [64, 3] = all records fit into 64 * 3 folders - * - [64, 64, 10] = all records fit into 64 * 64 * 10 folder - * (there are 64 possible chars in allIsChars) -*/ -const folderStructureArray = (recordNode) => { - - const totalFolders = Math.ceil(recordNode.estimatedRecordCount / 1000); - const folderArray = []; - let levelCount = 1; - while(64**levelCount < totalFolders) { - levelCount += 1; - folderArray.push(64); - } - - const parentFactor = (64**folderArray.length); - if(parentFactor < totalFolders) { - folderArray.push( - Math.ceil(totalFolders / parentFactor) - ); - } - - return folderArray; - - /* - const maxRecords = currentFolderPosition === 0 - ? RECORDS_PER_FOLDER - : currentFolderPosition * 64 * RECORDS_PER_FOLDER; - - if(maxRecords < recordNode.estimatedRecordCount) { - return folderStructureArray( - recordNode, - [...currentArray, 64], - currentFolderPosition + 1); - } else { - const childFolderCount = Math.ceil(recordNode.estimatedRecordCount / maxRecords ); - return [...currentArray, childFolderCount] - }*/ -}; - - -const getAllIdsIterator = app => async (collection_Key_or_NodeKey) => { - collection_Key_or_NodeKey = safeKey(collection_Key_or_NodeKey); - const recordNode = getCollectionNodeByKeyOrNodeKey( - app.hierarchy, - collection_Key_or_NodeKey, - ); - - const getAllIdsIteratorForCollectionKey = async (recordNode, collectionKey) => { - - const folderStructure = folderStructureArray(recordNode); - - let currentFolderContents = []; - let currentPosition = []; - - const collectionDir = getCollectionDir(app.hierarchy, collectionKey); - const basePath = joinKey( - collectionDir, recordNode.nodeId.toString()); - - - - // "folderStructure" determines the top, sharding folders - // we need to add one, for the collection root folder, which - // always exists - const levels = folderStructure.length + 1; - const topLevel = levels -1; - - - /* populate initial directory structure in form: - [ - {path: "/a", contents: ["b", "c", "d"]}, - {path: "/a/b", contents: ["e","f","g"]}, - {path: "/a/b/e", contents: ["1-abcd","2-cdef","3-efgh"]}, - ] - // stores contents on each parent level - // top level has ID folders - */ - const firstFolder = async () => { - - let folderLevel = 0; - - const lastPathHasContent = () => - folderLevel === 0 - || currentFolderContents[folderLevel - 1].contents.length > 0; - - - while (folderLevel <= topLevel && lastPathHasContent()) { - - let thisPath = basePath; - for(let lev = 0; lev < currentPosition.length; lev++) { - thisPath = joinKey( - thisPath, currentFolderContents[lev].contents[0]); - } - - const contentsThisLevel = - await app.datastore.getFolderContents(thisPath); - currentFolderContents.push({ - contents:contentsThisLevel, - path: thisPath - }); - - // should start as something like [0,0] - if(folderLevel < topLevel) - currentPosition.push(0); - - folderLevel+=1; - } - - return (currentPosition.length === levels - 1); - }; - - const isOnLastFolder = level => { - - const result = currentPosition[level] === currentFolderContents[level].contents.length - 1; - return result; - }; - - const getNextFolder = async (lev=undefined) => { - lev = fp.isUndefined(lev) ? topLevel : lev; - const parentLev = lev - 1; - - if(parentLev < 0) return false; - - if(isOnLastFolder(parentLev)) { - return await getNextFolder(parentLev); - } - - const newPosition = currentPosition[parentLev] + 1; - currentPosition[parentLev] = newPosition; - - const nextFolder = joinKey( - currentFolderContents[parentLev].path, - currentFolderContents[parentLev].contents[newPosition]); - currentFolderContents[lev].contents = await app.datastore.getFolderContents( - nextFolder - ); - currentFolderContents[lev].path = nextFolder; - - if(lev !== topLevel) { - - // we just advanced a parent folder, so now need to - // do the same to the next levels - let loopLevel = lev + 1; - while(loopLevel <= topLevel) { - const loopParentLevel = loopLevel-1; - - currentPosition[loopParentLevel] = 0; - const nextLoopFolder = joinKey( - currentFolderContents[loopParentLevel].path, - currentFolderContents[loopParentLevel].contents[0]); - currentFolderContents[loopLevel].contents = await app.datastore.getFolderContents( - nextLoopFolder - ); - currentFolderContents[loopLevel].path = nextLoopFolder; - loopLevel+=1; - } - } - - // true ==has more ids... (just loaded more) - return true; - }; - - - const idsCurrentFolder = () => - currentFolderContents[currentFolderContents.length - 1].contents; - - const fininshedResult = ({ done: true, result: { ids: [], collectionKey } }); - - let hasStarted = false; - let hasMore = true; - const getIdsFromCurrentfolder = async () => { - - if(!hasMore) { - return fininshedResult; - } - - if(!hasStarted) { - hasMore = await firstFolder(); - hasStarted = true; - return ({ - result: { - ids: idsCurrentFolder(), - collectionKey - }, - done: false - }) - } - - hasMore = await getNextFolder(); - - return ({ - result: { - ids: hasMore ? idsCurrentFolder() : [], - collectionKey - }, - done: !hasMore - }); - }; - - return getIdsFromCurrentfolder; - - }; - - const ancestors = $(getFlattenedHierarchy(app.hierarchy), [ - fp.filter(isCollectionRecord), - fp.filter(n => isAncestor(recordNode)(n) - || n.nodeKey() === recordNode.nodeKey()), - fp.orderBy([n => n.nodeKey().length], ['asc']), - ]); // parents first - - const traverseForIteraterators = async (parentRecordKey = '', currentNodeIndex = 0) => { - const currentNode = ancestors[currentNodeIndex]; - const currentCollectionKey = joinKey( - parentRecordKey, - currentNode.collectionName, - ); - if (currentNode.nodeKey() === recordNode.nodeKey()) { - return [ - await getAllIdsIteratorForCollectionKey( - currentNode, - currentCollectionKey, - )]; - } - const allIterators = []; - const currentIterator = await getAllIdsIteratorForCollectionKey( - currentNode, - currentCollectionKey, - ); - - let ids = await currentIterator(); - while (ids.done === false) { - for (const id of ids.result.ids) { - allIterators.push( - await traverseForIteraterators( - joinKey(currentCollectionKey, id), - currentNodeIndex + 1, - ), - ); - } - - ids = await currentIterator(); - } - - return fp.flatten(allIterators); - }; - - const iteratorsArray = await traverseForIteraterators(); - let currentIteratorIndex = 0; - return async () => { - if (iteratorsArray.length === 0) { return { done: true, result: [] }; } - const innerResult = await iteratorsArray[currentIteratorIndex](); - if (!innerResult.done) { return innerResult; } - if (currentIteratorIndex == iteratorsArray.length - 1) { - return { done: true, result: innerResult.result }; - } - currentIteratorIndex++; - return { done: false, result: innerResult.result }; - }; -}; - -const getRecordInfo = (hierarchy, key) => { - const recordNode = getExactNodeForKey(hierarchy)(key); - const pathInfo = getRecordDirectory(recordNode, key); - const dir = joinKey(pathInfo.base, ...pathInfo.subdirs); - - return { - recordJson: recordJson(dir), - files: files(dir), - child:(name) => joinKey(dir, name), - key: safeKey(key), - recordNode, pathInfo, dir - }; -}; - -const getCollectionDir = (hierarchy, collectionKey) => { - const recordNode = getNodeForCollectionPath(hierarchy)(collectionKey); - const dummyRecordKey = joinKey(collectionKey, "1-abcd"); - const pathInfo = getRecordDirectory(recordNode, dummyRecordKey); - return pathInfo.base; -}; - -const recordJson = (dir) => - joinKey(dir, "record.json"); - -const files = (dir) => - joinKey(dir, "files"); - -const getRecordDirectory = (recordNode, key) => { - const id = getFileFromKey(key); - - const traverseParentKeys = (n, parents=[]) => { - if(isRoot(n)) return parents; - const k = getActualKeyOfParent(n.nodeKey(), key); - const thisNodeDir = { - node:n, - relativeDir: joinKey( - recordRelativeDirectory(n, getFileFromKey(k))) - }; - return traverseParentKeys( - n.parent(), - [thisNodeDir, ...parents]); - }; - - const parentDirs = $(recordNode.parent(), [ - traverseParentKeys, - fp.reduce((key, item) => { - return joinKey(key, item.node.collectionName, item.relativeDir) - }, keySep) - ]); - - const subdirs = isSingleRecord(recordNode) - ? [] - : recordRelativeDirectory(recordNode, id); - const base = isSingleRecord(recordNode) - ? joinKey(parentDirs, recordNode.name) - : joinKey(parentDirs, recordNode.collectionName); - - return ({ - subdirs, base - }); -}; - -const recordRelativeDirectory = (recordNode, id) => { - const folderStructure = folderStructureArray(recordNode); - const strippedId = id.substring(recordNode.nodeId.toString().length + 1); - const subfolders = $(folderStructure, [ - fp.reduce((result, currentCount) => { - result.folders.push( - folderForChar(strippedId[result.level], currentCount) - ); - return {level:result.level+1, folders:result.folders}; - }, {level:0, folders:[]}), - f => f.folders, - fp.filter(f => !!f) - ]); - - return [recordNode.nodeId.toString(), ...subfolders, id] -}; - -const folderForChar = (char, folderCount) => - folderCount === 1 ? "" - : $(folderCount, [ - idFoldersForFolderCount, - fp.find(f => f.includes(char)) - ]); - -const idFoldersForFolderCount = (folderCount) => { - const charRangePerShard = 64 / folderCount; - const idFolders = []; - let index = 0; - let currentIdsShard = ''; - while (index < 64) { - currentIdsShard += allIdChars[index]; - if ((index + 1) % charRangePerShard === 0) { - idFolders.push(currentIdsShard); - currentIdsShard = ''; - } - index++; - } - - return idFolders; -}; - -const load = app => async key => { - key = safeKey(key); - return apiWrapper( - app, - events.recordApi.load, - permission.readRecord.isAuthorized(key), - { key }, - _load, app, key, - ); -}; - -const _loadFromInfo = async (app, recordInfo, keyStack = []) => { - const key = recordInfo.key; - const {recordNode, recordJson} = recordInfo; - const storedData = await app.datastore.loadJson(recordJson); - - const loadedRecord = $(recordNode.fields, [ - fp.keyBy('name'), - fp.mapValues(f => safeParseField(f, storedData)), - ]); - - const newKeyStack = [...keyStack, key]; - - const references = $(recordNode.fields, [ - fp.filter(f => f.type === 'reference' - && isNonEmptyString(loadedRecord[f.name].key) - && !fp.includes(loadedRecord[f.name].key)(newKeyStack)), - fp.map(f => ({ - promise: _load(app, loadedRecord[f.name].key, newKeyStack), - index: getNode(app.hierarchy, f.typeOptions.indexNodeKey), - field: f, - })), - ]); - - if (references.length > 0) { - const refRecords = await Promise.all( - fp.map(p => p.promise)(references), - ); - - for (const ref of references) { - loadedRecord[ref.field.name] = mapRecord( - refRecords[references.indexOf(ref)], - ref.index, - ); - } - } - - loadedRecord.transactionId = storedData.transactionId; - loadedRecord.isNew = false; - loadedRecord.key = key; - loadedRecord.id = $(key, [splitKey, fp.last]); - loadedRecord.type = recordNode.name; - return loadedRecord; -}; - -const _load = async (app, key, keyStack = []) => - _loadFromInfo( - app, - getRecordInfo(app.hierarchy, key), - keyStack); - -// adapted from https://github.com/dex4er/js-promise-readable -// thanks :) - -const promiseReadableStream = stream => { - - let _errored; - - const _errorHandler = err => { - _errored = err; - }; - - stream.on("error", _errorHandler); - - const read = (size) => { - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err) - } - - if (!stream.readable || stream.closed || stream.destroyed) { - return resolve(); - } - - const readableHandler = () => { - const chunk = stream.read(size); - - if (chunk) { - removeListeners(); - resolve(chunk); - } - }; - - const closeHandler = () => { - removeListeners(); - resolve(); - }; - - const endHandler = () => { - removeListeners(); - resolve(); - }; - - const errorHandler = (err) => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const removeListeners = () => { - stream.removeListener("close", closeHandler); - stream.removeListener("error", errorHandler); - stream.removeListener("end", endHandler); - stream.removeListener("readable", readableHandler); - }; - - stream.on("close", closeHandler); - stream.on("end", endHandler); - stream.on("error", errorHandler); - stream.on("readable", readableHandler); - - readableHandler(); - }); - }; - - - const destroy = () => { - if (stream) { - if (_errorHandler) { - stream.removeListener("error", _errorHandler); - } - if (typeof stream.destroy === "function") { - stream.destroy(); - } - } - }; - - return {read, destroy, stream}; - }; - -const getIndexedDataKey = (indexNode, indexDir, record) => { - - const getShardName = (indexNode, record) => { - const shardNameFunc = compilerUtil.compileCode(indexNode.getShardName); - try { - return shardNameFunc({ record }); - } catch(e) { - const errorDetails = `shardCode: ${indexNode.getShardName} :: record: ${JSON.stringify(record)} :: `; - e.message = "Error running index shardname func: " + errorDetails + e.message; - throw e; - } - }; - - const shardName = isNonEmptyString(indexNode.getShardName) - ? `${getShardName(indexNode, record)}.csv` - : 'index.csv'; - - return joinKey(indexDir, shardName); -}; - -const getShardKeysInRange = async (app, indexNode, indexDir, startRecord = null, endRecord = null) => { - const startShardName = !startRecord - ? null - : shardNameFromKey( - getIndexedDataKey( - indexNode, - indexDir, - startRecord, - ), - ); - - const endShardName = !endRecord - ? null - : shardNameFromKey( - getIndexedDataKey( - indexNode, - indexDir, - endRecord, - ), - ); - - return $(await getShardMap(app.datastore, indexDir), [ - fp.filter(k => (startRecord === null || k >= startShardName) - && (endRecord === null || k <= endShardName)), - fp.map(k => joinKey(indexDir, `${k}.csv`)), - ]); -}; - -const ensureShardNameIsInShardMap = async (store, indexDir, indexedDataKey) => { - const map = await getShardMap(store, indexDir); - const shardName = shardNameFromKey(indexedDataKey); - if (!fp.includes(shardName)(map)) { - map.push(shardName); - await writeShardMap(store, indexDir, map); - } -}; - -const getShardMap = async (datastore, indexDir) => { - const shardMapKey = getShardMapKey(indexDir); - try { - return await datastore.loadJson(shardMapKey); - } catch (_) { - await datastore.createJson(shardMapKey, []); - return []; - } -}; - -const writeShardMap = async (datastore, indexDir, shardMap) => await datastore.updateJson( - getShardMapKey(indexDir), - shardMap, -); - -const getShardMapKey = indexDir => joinKey(indexDir, 'shardMap.json'); - -const getUnshardedIndexDataKey = indexDir => joinKey(indexDir, 'index.csv'); - -const createIndexFile = async (datastore, indexedDataKey, index) => { - if (isShardedIndex(index)) { - const indexDir = getParentKey(indexedDataKey); - const shardMap = await getShardMap(datastore, indexDir); - shardMap.push( - shardNameFromKey(indexedDataKey), - ); - await writeShardMap(datastore, indexDir, shardMap); - } - await datastore.createFile(indexedDataKey, ''); -}; - -const shardNameFromKey = key => $(key, [ - splitKey, - fp.last, -]).replace('.csv', ''); - -const getIndexKey_BasedOnDecendant = (decendantKey, indexNode) => { - if (isGlobalIndex(indexNode)) { return `${indexNode.nodeKey()}`; } - - const indexedDataParentKey = getActualKeyOfParent( - indexNode.parent().nodeKey(), - decendantKey, - ); - - return joinKey( - indexedDataParentKey, - indexNode.name, - ); -}; - -const generateSchema = (hierarchy, indexNode) => { - const recordNodes = getAllowedRecordNodesForIndex(hierarchy, indexNode); - const mappedRecords = $(recordNodes, [ - fp.map(n => mapRecord(createSampleRecord(n), indexNode)), - ]); - - // always has record key and sort key - const schema = { - sortKey: all$1.string, - key: all$1.string, - }; - - const fieldsHas = fp.has(schema); - const setField = (fieldName, value) => { - if (value === null || value === undefined) { return; } - - const thisType = detectType(value); - if (fieldsHas(fieldName)) { - if (schema[fieldName] !== thisType) { - schema[fieldName] = all$1.string; - } - } else { - schema[fieldName] = thisType; - } - }; - - for (const mappedRec of mappedRecords) { - for (const f in mappedRec) { - setField(f, mappedRec[f]); - } - } - - // returing an array of {name, type} - return $(schema, [ - fp.keys, - fp.map(k => ({ name: k, type: schema[k].name })), - fp.filter(s => s.name !== 'sortKey'), - fp.orderBy('name', ['desc']), // reverse aplha - fp.concat([{ name: 'sortKey', type: all$1.string.name }]), // sortKey on end - fp.reverse, // sortKey first, then rest are alphabetical - ]); -}; - -const createSampleRecord = recordNode => constructRecord( - recordNode, - getSampleFieldValue, - recordNode.parent().nodeKey(), -); - -var global$1 = (typeof global !== "undefined" ? global : - typeof self !== "undefined" ? self : - typeof window !== "undefined" ? window : {}); - -var lookup = []; -var revLookup = []; -var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array; -var inited = false; -function init () { - inited = true; - var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; - for (var i = 0, len = code.length; i < len; ++i) { - lookup[i] = code[i]; - revLookup[code.charCodeAt(i)] = i; - } - - revLookup['-'.charCodeAt(0)] = 62; - revLookup['_'.charCodeAt(0)] = 63; -} - -function toByteArray (b64) { - if (!inited) { - init(); - } - var i, j, l, tmp, placeHolders, arr; - var len = b64.length; - - if (len % 4 > 0) { - throw new Error('Invalid string. Length must be a multiple of 4') - } - - // the number of equal signs (place holders) - // if there are two placeholders, than the two characters before it - // represent one byte - // if there is only one, then the three characters before it represent 2 bytes - // this is just a cheap hack to not do indexOf twice - placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0; - - // base64 is 4/3 + up to two characters of the original data - arr = new Arr(len * 3 / 4 - placeHolders); - - // if there are placeholders, only get up to the last complete 4 chars - l = placeHolders > 0 ? len - 4 : len; - - var L = 0; - - for (i = 0, j = 0; i < l; i += 4, j += 3) { - tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]; - arr[L++] = (tmp >> 16) & 0xFF; - arr[L++] = (tmp >> 8) & 0xFF; - arr[L++] = tmp & 0xFF; - } - - if (placeHolders === 2) { - tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4); - arr[L++] = tmp & 0xFF; - } else if (placeHolders === 1) { - tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2); - arr[L++] = (tmp >> 8) & 0xFF; - arr[L++] = tmp & 0xFF; - } - - return arr -} - -function tripletToBase64 (num) { - return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F] -} - -function encodeChunk (uint8, start, end) { - var tmp; - var output = []; - for (var i = start; i < end; i += 3) { - tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2]); - output.push(tripletToBase64(tmp)); - } - return output.join('') -} - -function fromByteArray (uint8) { - if (!inited) { - init(); - } - var tmp; - var len = uint8.length; - var extraBytes = len % 3; // if we have 1 byte left, pad 2 bytes - var output = ''; - var parts = []; - var maxChunkLength = 16383; // must be multiple of 3 - - // go through the array every three bytes, we'll deal with trailing stuff later - for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) { - parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength))); - } - - // pad the end with zeros, but make sure to not forget the extra bytes - if (extraBytes === 1) { - tmp = uint8[len - 1]; - output += lookup[tmp >> 2]; - output += lookup[(tmp << 4) & 0x3F]; - output += '=='; - } else if (extraBytes === 2) { - tmp = (uint8[len - 2] << 8) + (uint8[len - 1]); - output += lookup[tmp >> 10]; - output += lookup[(tmp >> 4) & 0x3F]; - output += lookup[(tmp << 2) & 0x3F]; - output += '='; - } - - parts.push(output); - - return parts.join('') -} - -function read (buffer, offset, isLE, mLen, nBytes) { - var e, m; - var eLen = nBytes * 8 - mLen - 1; - var eMax = (1 << eLen) - 1; - var eBias = eMax >> 1; - var nBits = -7; - var i = isLE ? (nBytes - 1) : 0; - var d = isLE ? -1 : 1; - var s = buffer[offset + i]; - - i += d; - - e = s & ((1 << (-nBits)) - 1); - s >>= (-nBits); - nBits += eLen; - for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {} - - m = e & ((1 << (-nBits)) - 1); - e >>= (-nBits); - nBits += mLen; - for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {} - - if (e === 0) { - e = 1 - eBias; - } else if (e === eMax) { - return m ? NaN : ((s ? -1 : 1) * Infinity) - } else { - m = m + Math.pow(2, mLen); - e = e - eBias; - } - return (s ? -1 : 1) * m * Math.pow(2, e - mLen) -} - -function write (buffer, value, offset, isLE, mLen, nBytes) { - var e, m, c; - var eLen = nBytes * 8 - mLen - 1; - var eMax = (1 << eLen) - 1; - var eBias = eMax >> 1; - var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0); - var i = isLE ? 0 : (nBytes - 1); - var d = isLE ? 1 : -1; - var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0; - - value = Math.abs(value); - - if (isNaN(value) || value === Infinity) { - m = isNaN(value) ? 1 : 0; - e = eMax; - } else { - e = Math.floor(Math.log(value) / Math.LN2); - if (value * (c = Math.pow(2, -e)) < 1) { - e--; - c *= 2; - } - if (e + eBias >= 1) { - value += rt / c; - } else { - value += rt * Math.pow(2, 1 - eBias); - } - if (value * c >= 2) { - e++; - c /= 2; - } - - if (e + eBias >= eMax) { - m = 0; - e = eMax; - } else if (e + eBias >= 1) { - m = (value * c - 1) * Math.pow(2, mLen); - e = e + eBias; - } else { - m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen); - e = 0; - } - } - - for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} - - e = (e << mLen) | m; - eLen += mLen; - for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} - - buffer[offset + i - d] |= s * 128; -} - -var toString = {}.toString; - -var isArray = Array.isArray || function (arr) { - return toString.call(arr) == '[object Array]'; -}; - -var INSPECT_MAX_BYTES = 50; - -/** - * If `Buffer.TYPED_ARRAY_SUPPORT`: - * === true Use Uint8Array implementation (fastest) - * === false Use Object implementation (most compatible, even IE6) - * - * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, - * Opera 11.6+, iOS 4.2+. - * - * Due to various browser bugs, sometimes the Object implementation will be used even - * when the browser supports typed arrays. - * - * Note: - * - * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances, - * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438. - * - * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function. - * - * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of - * incorrect length in some situations. - - * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they - * get the Object implementation, which is slower but behaves correctly. - */ -Buffer.TYPED_ARRAY_SUPPORT = global$1.TYPED_ARRAY_SUPPORT !== undefined - ? global$1.TYPED_ARRAY_SUPPORT - : true; - -function kMaxLength () { - return Buffer.TYPED_ARRAY_SUPPORT - ? 0x7fffffff - : 0x3fffffff -} - -function createBuffer (that, length) { - if (kMaxLength() < length) { - throw new RangeError('Invalid typed array length') - } - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - that = new Uint8Array(length); - that.__proto__ = Buffer.prototype; - } else { - // Fallback: Return an object instance of the Buffer class - if (that === null) { - that = new Buffer(length); - } - that.length = length; - } - - return that -} - -/** - * The Buffer constructor returns instances of `Uint8Array` that have their - * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of - * `Uint8Array`, so the returned instances will have all the node `Buffer` methods - * and the `Uint8Array` methods. Square bracket notation works as expected -- it - * returns a single octet. - * - * The `Uint8Array` prototype remains unmodified. - */ - -function Buffer (arg, encodingOrOffset, length) { - if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) { - return new Buffer(arg, encodingOrOffset, length) - } - - // Common case. - if (typeof arg === 'number') { - if (typeof encodingOrOffset === 'string') { - throw new Error( - 'If encoding is specified then the first argument must be a string' - ) - } - return allocUnsafe(this, arg) - } - return from(this, arg, encodingOrOffset, length) -} - -Buffer.poolSize = 8192; // not used by this implementation - -// TODO: Legacy, not needed anymore. Remove in next major version. -Buffer._augment = function (arr) { - arr.__proto__ = Buffer.prototype; - return arr -}; - -function from (that, value, encodingOrOffset, length) { - if (typeof value === 'number') { - throw new TypeError('"value" argument must not be a number') - } - - if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) { - return fromArrayBuffer(that, value, encodingOrOffset, length) - } - - if (typeof value === 'string') { - return fromString(that, value, encodingOrOffset) - } - - return fromObject(that, value) -} - -/** - * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError - * if value is a number. - * Buffer.from(str[, encoding]) - * Buffer.from(array) - * Buffer.from(buffer) - * Buffer.from(arrayBuffer[, byteOffset[, length]]) - **/ -Buffer.from = function (value, encodingOrOffset, length) { - return from(null, value, encodingOrOffset, length) -}; - -if (Buffer.TYPED_ARRAY_SUPPORT) { - Buffer.prototype.__proto__ = Uint8Array.prototype; - Buffer.__proto__ = Uint8Array; -} - -function assertSize (size) { - if (typeof size !== 'number') { - throw new TypeError('"size" argument must be a number') - } else if (size < 0) { - throw new RangeError('"size" argument must not be negative') - } -} - -function alloc (that, size, fill, encoding) { - assertSize(size); - if (size <= 0) { - return createBuffer(that, size) - } - if (fill !== undefined) { - // Only pay attention to encoding if it's a string. This - // prevents accidentally sending in a number that would - // be interpretted as a start offset. - return typeof encoding === 'string' - ? createBuffer(that, size).fill(fill, encoding) - : createBuffer(that, size).fill(fill) - } - return createBuffer(that, size) -} - -/** - * Creates a new filled Buffer instance. - * alloc(size[, fill[, encoding]]) - **/ -Buffer.alloc = function (size, fill, encoding) { - return alloc(null, size, fill, encoding) -}; - -function allocUnsafe (that, size) { - assertSize(size); - that = createBuffer(that, size < 0 ? 0 : checked(size) | 0); - if (!Buffer.TYPED_ARRAY_SUPPORT) { - for (var i = 0; i < size; ++i) { - that[i] = 0; - } - } - return that -} - -/** - * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance. - * */ -Buffer.allocUnsafe = function (size) { - return allocUnsafe(null, size) -}; -/** - * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance. - */ -Buffer.allocUnsafeSlow = function (size) { - return allocUnsafe(null, size) -}; - -function fromString (that, string, encoding) { - if (typeof encoding !== 'string' || encoding === '') { - encoding = 'utf8'; - } - - if (!Buffer.isEncoding(encoding)) { - throw new TypeError('"encoding" must be a valid string encoding') - } - - var length = byteLength(string, encoding) | 0; - that = createBuffer(that, length); - - var actual = that.write(string, encoding); - - if (actual !== length) { - // Writing a hex string, for example, that contains invalid characters will - // cause everything after the first invalid character to be ignored. (e.g. - // 'abxxcd' will be treated as 'ab') - that = that.slice(0, actual); - } - - return that -} - -function fromArrayLike (that, array) { - var length = array.length < 0 ? 0 : checked(array.length) | 0; - that = createBuffer(that, length); - for (var i = 0; i < length; i += 1) { - that[i] = array[i] & 255; - } - return that -} - -function fromArrayBuffer (that, array, byteOffset, length) { - array.byteLength; // this throws if `array` is not a valid ArrayBuffer - - if (byteOffset < 0 || array.byteLength < byteOffset) { - throw new RangeError('\'offset\' is out of bounds') - } - - if (array.byteLength < byteOffset + (length || 0)) { - throw new RangeError('\'length\' is out of bounds') - } - - if (byteOffset === undefined && length === undefined) { - array = new Uint8Array(array); - } else if (length === undefined) { - array = new Uint8Array(array, byteOffset); - } else { - array = new Uint8Array(array, byteOffset, length); - } - - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - that = array; - that.__proto__ = Buffer.prototype; - } else { - // Fallback: Return an object instance of the Buffer class - that = fromArrayLike(that, array); - } - return that -} - -function fromObject (that, obj) { - if (internalIsBuffer(obj)) { - var len = checked(obj.length) | 0; - that = createBuffer(that, len); - - if (that.length === 0) { - return that - } - - obj.copy(that, 0, 0, len); - return that - } - - if (obj) { - if ((typeof ArrayBuffer !== 'undefined' && - obj.buffer instanceof ArrayBuffer) || 'length' in obj) { - if (typeof obj.length !== 'number' || isnan(obj.length)) { - return createBuffer(that, 0) - } - return fromArrayLike(that, obj) - } - - if (obj.type === 'Buffer' && isArray(obj.data)) { - return fromArrayLike(that, obj.data) - } - } - - throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.') -} - -function checked (length) { - // Note: cannot use `length < kMaxLength()` here because that fails when - // length is NaN (which is otherwise coerced to zero.) - if (length >= kMaxLength()) { - throw new RangeError('Attempt to allocate Buffer larger than maximum ' + - 'size: 0x' + kMaxLength().toString(16) + ' bytes') - } - return length | 0 -} -Buffer.isBuffer = isBuffer; -function internalIsBuffer (b) { - return !!(b != null && b._isBuffer) -} - -Buffer.compare = function compare (a, b) { - if (!internalIsBuffer(a) || !internalIsBuffer(b)) { - throw new TypeError('Arguments must be Buffers') - } - - if (a === b) return 0 - - var x = a.length; - var y = b.length; - - for (var i = 0, len = Math.min(x, y); i < len; ++i) { - if (a[i] !== b[i]) { - x = a[i]; - y = b[i]; - break - } - } - - if (x < y) return -1 - if (y < x) return 1 - return 0 -}; - -Buffer.isEncoding = function isEncoding (encoding) { - switch (String(encoding).toLowerCase()) { - case 'hex': - case 'utf8': - case 'utf-8': - case 'ascii': - case 'latin1': - case 'binary': - case 'base64': - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return true - default: - return false - } -}; - -Buffer.concat = function concat (list, length) { - if (!isArray(list)) { - throw new TypeError('"list" argument must be an Array of Buffers') - } - - if (list.length === 0) { - return Buffer.alloc(0) - } - - var i; - if (length === undefined) { - length = 0; - for (i = 0; i < list.length; ++i) { - length += list[i].length; - } - } - - var buffer = Buffer.allocUnsafe(length); - var pos = 0; - for (i = 0; i < list.length; ++i) { - var buf = list[i]; - if (!internalIsBuffer(buf)) { - throw new TypeError('"list" argument must be an Array of Buffers') - } - buf.copy(buffer, pos); - pos += buf.length; - } - return buffer -}; - -function byteLength (string, encoding) { - if (internalIsBuffer(string)) { - return string.length - } - if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' && - (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) { - return string.byteLength - } - if (typeof string !== 'string') { - string = '' + string; - } - - var len = string.length; - if (len === 0) return 0 - - // Use a for loop to avoid recursion - var loweredCase = false; - for (;;) { - switch (encoding) { - case 'ascii': - case 'latin1': - case 'binary': - return len - case 'utf8': - case 'utf-8': - case undefined: - return utf8ToBytes(string).length - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return len * 2 - case 'hex': - return len >>> 1 - case 'base64': - return base64ToBytes(string).length - default: - if (loweredCase) return utf8ToBytes(string).length // assume utf8 - encoding = ('' + encoding).toLowerCase(); - loweredCase = true; - } - } -} -Buffer.byteLength = byteLength; - -function slowToString (encoding, start, end) { - var loweredCase = false; - - // No need to verify that "this.length <= MAX_UINT32" since it's a read-only - // property of a typed array. - - // This behaves neither like String nor Uint8Array in that we set start/end - // to their upper/lower bounds if the value passed is out of range. - // undefined is handled specially as per ECMA-262 6th Edition, - // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization. - if (start === undefined || start < 0) { - start = 0; - } - // Return early if start > this.length. Done here to prevent potential uint32 - // coercion fail below. - if (start > this.length) { - return '' - } - - if (end === undefined || end > this.length) { - end = this.length; - } - - if (end <= 0) { - return '' - } - - // Force coersion to uint32. This will also coerce falsey/NaN values to 0. - end >>>= 0; - start >>>= 0; - - if (end <= start) { - return '' - } - - if (!encoding) encoding = 'utf8'; - - while (true) { - switch (encoding) { - case 'hex': - return hexSlice(this, start, end) - - case 'utf8': - case 'utf-8': - return utf8Slice(this, start, end) - - case 'ascii': - return asciiSlice(this, start, end) - - case 'latin1': - case 'binary': - return latin1Slice(this, start, end) - - case 'base64': - return base64Slice(this, start, end) - - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return utf16leSlice(this, start, end) - - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = (encoding + '').toLowerCase(); - loweredCase = true; - } - } -} - -// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect -// Buffer instances. -Buffer.prototype._isBuffer = true; - -function swap (b, n, m) { - var i = b[n]; - b[n] = b[m]; - b[m] = i; -} - -Buffer.prototype.swap16 = function swap16 () { - var len = this.length; - if (len % 2 !== 0) { - throw new RangeError('Buffer size must be a multiple of 16-bits') - } - for (var i = 0; i < len; i += 2) { - swap(this, i, i + 1); - } - return this -}; - -Buffer.prototype.swap32 = function swap32 () { - var len = this.length; - if (len % 4 !== 0) { - throw new RangeError('Buffer size must be a multiple of 32-bits') - } - for (var i = 0; i < len; i += 4) { - swap(this, i, i + 3); - swap(this, i + 1, i + 2); - } - return this -}; - -Buffer.prototype.swap64 = function swap64 () { - var len = this.length; - if (len % 8 !== 0) { - throw new RangeError('Buffer size must be a multiple of 64-bits') - } - for (var i = 0; i < len; i += 8) { - swap(this, i, i + 7); - swap(this, i + 1, i + 6); - swap(this, i + 2, i + 5); - swap(this, i + 3, i + 4); - } - return this -}; - -Buffer.prototype.toString = function toString () { - var length = this.length | 0; - if (length === 0) return '' - if (arguments.length === 0) return utf8Slice(this, 0, length) - return slowToString.apply(this, arguments) -}; - -Buffer.prototype.equals = function equals (b) { - if (!internalIsBuffer(b)) throw new TypeError('Argument must be a Buffer') - if (this === b) return true - return Buffer.compare(this, b) === 0 -}; - -Buffer.prototype.inspect = function inspect () { - var str = ''; - var max = INSPECT_MAX_BYTES; - if (this.length > 0) { - str = this.toString('hex', 0, max).match(/.{2}/g).join(' '); - if (this.length > max) str += ' ... '; - } - return '' -}; - -Buffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) { - if (!internalIsBuffer(target)) { - throw new TypeError('Argument must be a Buffer') - } - - if (start === undefined) { - start = 0; - } - if (end === undefined) { - end = target ? target.length : 0; - } - if (thisStart === undefined) { - thisStart = 0; - } - if (thisEnd === undefined) { - thisEnd = this.length; - } - - if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) { - throw new RangeError('out of range index') - } - - if (thisStart >= thisEnd && start >= end) { - return 0 - } - if (thisStart >= thisEnd) { - return -1 - } - if (start >= end) { - return 1 - } - - start >>>= 0; - end >>>= 0; - thisStart >>>= 0; - thisEnd >>>= 0; - - if (this === target) return 0 - - var x = thisEnd - thisStart; - var y = end - start; - var len = Math.min(x, y); - - var thisCopy = this.slice(thisStart, thisEnd); - var targetCopy = target.slice(start, end); - - for (var i = 0; i < len; ++i) { - if (thisCopy[i] !== targetCopy[i]) { - x = thisCopy[i]; - y = targetCopy[i]; - break - } - } - - if (x < y) return -1 - if (y < x) return 1 - return 0 -}; - -// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`, -// OR the last index of `val` in `buffer` at offset <= `byteOffset`. -// -// Arguments: -// - buffer - a Buffer to search -// - val - a string, Buffer, or number -// - byteOffset - an index into `buffer`; will be clamped to an int32 -// - encoding - an optional encoding, relevant is val is a string -// - dir - true for indexOf, false for lastIndexOf -function bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) { - // Empty buffer means no match - if (buffer.length === 0) return -1 - - // Normalize byteOffset - if (typeof byteOffset === 'string') { - encoding = byteOffset; - byteOffset = 0; - } else if (byteOffset > 0x7fffffff) { - byteOffset = 0x7fffffff; - } else if (byteOffset < -0x80000000) { - byteOffset = -0x80000000; - } - byteOffset = +byteOffset; // Coerce to Number. - if (isNaN(byteOffset)) { - // byteOffset: it it's undefined, null, NaN, "foo", etc, search whole buffer - byteOffset = dir ? 0 : (buffer.length - 1); - } - - // Normalize byteOffset: negative offsets start from the end of the buffer - if (byteOffset < 0) byteOffset = buffer.length + byteOffset; - if (byteOffset >= buffer.length) { - if (dir) return -1 - else byteOffset = buffer.length - 1; - } else if (byteOffset < 0) { - if (dir) byteOffset = 0; - else return -1 - } - - // Normalize val - if (typeof val === 'string') { - val = Buffer.from(val, encoding); - } - - // Finally, search either indexOf (if dir is true) or lastIndexOf - if (internalIsBuffer(val)) { - // Special case: looking for empty string/buffer always fails - if (val.length === 0) { - return -1 - } - return arrayIndexOf(buffer, val, byteOffset, encoding, dir) - } else if (typeof val === 'number') { - val = val & 0xFF; // Search for a byte value [0-255] - if (Buffer.TYPED_ARRAY_SUPPORT && - typeof Uint8Array.prototype.indexOf === 'function') { - if (dir) { - return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset) - } else { - return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset) - } - } - return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir) - } - - throw new TypeError('val must be string, number or Buffer') -} - -function arrayIndexOf (arr, val, byteOffset, encoding, dir) { - var indexSize = 1; - var arrLength = arr.length; - var valLength = val.length; - - if (encoding !== undefined) { - encoding = String(encoding).toLowerCase(); - if (encoding === 'ucs2' || encoding === 'ucs-2' || - encoding === 'utf16le' || encoding === 'utf-16le') { - if (arr.length < 2 || val.length < 2) { - return -1 - } - indexSize = 2; - arrLength /= 2; - valLength /= 2; - byteOffset /= 2; - } - } - - function read (buf, i) { - if (indexSize === 1) { - return buf[i] - } else { - return buf.readUInt16BE(i * indexSize) - } - } - - var i; - if (dir) { - var foundIndex = -1; - for (i = byteOffset; i < arrLength; i++) { - if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) { - if (foundIndex === -1) foundIndex = i; - if (i - foundIndex + 1 === valLength) return foundIndex * indexSize - } else { - if (foundIndex !== -1) i -= i - foundIndex; - foundIndex = -1; - } - } - } else { - if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength; - for (i = byteOffset; i >= 0; i--) { - var found = true; - for (var j = 0; j < valLength; j++) { - if (read(arr, i + j) !== read(val, j)) { - found = false; - break - } - } - if (found) return i - } - } - - return -1 -} - -Buffer.prototype.includes = function includes (val, byteOffset, encoding) { - return this.indexOf(val, byteOffset, encoding) !== -1 -}; - -Buffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) { - return bidirectionalIndexOf(this, val, byteOffset, encoding, true) -}; - -Buffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) { - return bidirectionalIndexOf(this, val, byteOffset, encoding, false) -}; - -function hexWrite (buf, string, offset, length) { - offset = Number(offset) || 0; - var remaining = buf.length - offset; - if (!length) { - length = remaining; - } else { - length = Number(length); - if (length > remaining) { - length = remaining; - } - } - - // must be an even number of digits - var strLen = string.length; - if (strLen % 2 !== 0) throw new TypeError('Invalid hex string') - - if (length > strLen / 2) { - length = strLen / 2; - } - for (var i = 0; i < length; ++i) { - var parsed = parseInt(string.substr(i * 2, 2), 16); - if (isNaN(parsed)) return i - buf[offset + i] = parsed; - } - return i -} - -function utf8Write (buf, string, offset, length) { - return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) -} - -function asciiWrite (buf, string, offset, length) { - return blitBuffer(asciiToBytes(string), buf, offset, length) -} - -function latin1Write (buf, string, offset, length) { - return asciiWrite(buf, string, offset, length) -} - -function base64Write (buf, string, offset, length) { - return blitBuffer(base64ToBytes(string), buf, offset, length) -} - -function ucs2Write (buf, string, offset, length) { - return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) -} - -Buffer.prototype.write = function write (string, offset, length, encoding) { - // Buffer#write(string) - if (offset === undefined) { - encoding = 'utf8'; - length = this.length; - offset = 0; - // Buffer#write(string, encoding) - } else if (length === undefined && typeof offset === 'string') { - encoding = offset; - length = this.length; - offset = 0; - // Buffer#write(string, offset[, length][, encoding]) - } else if (isFinite(offset)) { - offset = offset | 0; - if (isFinite(length)) { - length = length | 0; - if (encoding === undefined) encoding = 'utf8'; - } else { - encoding = length; - length = undefined; - } - // legacy write(string, encoding, offset, length) - remove in v0.13 - } else { - throw new Error( - 'Buffer.write(string, encoding, offset[, length]) is no longer supported' - ) - } - - var remaining = this.length - offset; - if (length === undefined || length > remaining) length = remaining; - - if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { - throw new RangeError('Attempt to write outside buffer bounds') - } - - if (!encoding) encoding = 'utf8'; - - var loweredCase = false; - for (;;) { - switch (encoding) { - case 'hex': - return hexWrite(this, string, offset, length) - - case 'utf8': - case 'utf-8': - return utf8Write(this, string, offset, length) - - case 'ascii': - return asciiWrite(this, string, offset, length) - - case 'latin1': - case 'binary': - return latin1Write(this, string, offset, length) - - case 'base64': - // Warning: maxLength not taken into account in base64Write - return base64Write(this, string, offset, length) - - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return ucs2Write(this, string, offset, length) - - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = ('' + encoding).toLowerCase(); - loweredCase = true; - } - } -}; - -Buffer.prototype.toJSON = function toJSON () { - return { - type: 'Buffer', - data: Array.prototype.slice.call(this._arr || this, 0) - } -}; - -function base64Slice (buf, start, end) { - if (start === 0 && end === buf.length) { - return fromByteArray(buf) - } else { - return fromByteArray(buf.slice(start, end)) - } -} - -function utf8Slice (buf, start, end) { - end = Math.min(buf.length, end); - var res = []; - - var i = start; - while (i < end) { - var firstByte = buf[i]; - var codePoint = null; - var bytesPerSequence = (firstByte > 0xEF) ? 4 - : (firstByte > 0xDF) ? 3 - : (firstByte > 0xBF) ? 2 - : 1; - - if (i + bytesPerSequence <= end) { - var secondByte, thirdByte, fourthByte, tempCodePoint; - - switch (bytesPerSequence) { - case 1: - if (firstByte < 0x80) { - codePoint = firstByte; - } - break - case 2: - secondByte = buf[i + 1]; - if ((secondByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F); - if (tempCodePoint > 0x7F) { - codePoint = tempCodePoint; - } - } - break - case 3: - secondByte = buf[i + 1]; - thirdByte = buf[i + 2]; - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F); - if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { - codePoint = tempCodePoint; - } - } - break - case 4: - secondByte = buf[i + 1]; - thirdByte = buf[i + 2]; - fourthByte = buf[i + 3]; - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F); - if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { - codePoint = tempCodePoint; - } - } - } - } - - if (codePoint === null) { - // we did not generate a valid codePoint so insert a - // replacement char (U+FFFD) and advance only 1 byte - codePoint = 0xFFFD; - bytesPerSequence = 1; - } else if (codePoint > 0xFFFF) { - // encode to utf16 (surrogate pair dance) - codePoint -= 0x10000; - res.push(codePoint >>> 10 & 0x3FF | 0xD800); - codePoint = 0xDC00 | codePoint & 0x3FF; - } - - res.push(codePoint); - i += bytesPerSequence; - } - - return decodeCodePointsArray(res) -} - -// Based on http://stackoverflow.com/a/22747272/680742, the browser with -// the lowest limit is Chrome, with 0x10000 args. -// We go 1 magnitude less, for safety -var MAX_ARGUMENTS_LENGTH = 0x1000; - -function decodeCodePointsArray (codePoints) { - var len = codePoints.length; - if (len <= MAX_ARGUMENTS_LENGTH) { - return String.fromCharCode.apply(String, codePoints) // avoid extra slice() - } - - // Decode in chunks to avoid "call stack size exceeded". - var res = ''; - var i = 0; - while (i < len) { - res += String.fromCharCode.apply( - String, - codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) - ); - } - return res -} - -function asciiSlice (buf, start, end) { - var ret = ''; - end = Math.min(buf.length, end); - - for (var i = start; i < end; ++i) { - ret += String.fromCharCode(buf[i] & 0x7F); - } - return ret -} - -function latin1Slice (buf, start, end) { - var ret = ''; - end = Math.min(buf.length, end); - - for (var i = start; i < end; ++i) { - ret += String.fromCharCode(buf[i]); - } - return ret -} - -function hexSlice (buf, start, end) { - var len = buf.length; - - if (!start || start < 0) start = 0; - if (!end || end < 0 || end > len) end = len; - - var out = ''; - for (var i = start; i < end; ++i) { - out += toHex(buf[i]); - } - return out -} - -function utf16leSlice (buf, start, end) { - var bytes = buf.slice(start, end); - var res = ''; - for (var i = 0; i < bytes.length; i += 2) { - res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256); - } - return res -} - -Buffer.prototype.slice = function slice (start, end) { - var len = this.length; - start = ~~start; - end = end === undefined ? len : ~~end; - - if (start < 0) { - start += len; - if (start < 0) start = 0; - } else if (start > len) { - start = len; - } - - if (end < 0) { - end += len; - if (end < 0) end = 0; - } else if (end > len) { - end = len; - } - - if (end < start) end = start; - - var newBuf; - if (Buffer.TYPED_ARRAY_SUPPORT) { - newBuf = this.subarray(start, end); - newBuf.__proto__ = Buffer.prototype; - } else { - var sliceLen = end - start; - newBuf = new Buffer(sliceLen, undefined); - for (var i = 0; i < sliceLen; ++i) { - newBuf[i] = this[i + start]; - } - } - - return newBuf -}; - -/* - * Need to make sure that buffer isn't trying to write out of bounds. - */ -function checkOffset (offset, ext, length) { - if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') - if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') -} - -Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var val = this[offset]; - var mul = 1; - var i = 0; - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul; - } - - return val -}; - -Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - checkOffset(offset, byteLength, this.length); - } - - var val = this[offset + --byteLength]; - var mul = 1; - while (byteLength > 0 && (mul *= 0x100)) { - val += this[offset + --byteLength] * mul; - } - - return val -}; - -Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length); - return this[offset] -}; - -Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - return this[offset] | (this[offset + 1] << 8) -}; - -Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - return (this[offset] << 8) | this[offset + 1] -}; - -Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return ((this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16)) + - (this[offset + 3] * 0x1000000) -}; - -Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset] * 0x1000000) + - ((this[offset + 1] << 16) | - (this[offset + 2] << 8) | - this[offset + 3]) -}; - -Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var val = this[offset]; - var mul = 1; - var i = 0; - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul; - } - mul *= 0x80; - - if (val >= mul) val -= Math.pow(2, 8 * byteLength); - - return val -}; - -Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var i = byteLength; - var mul = 1; - var val = this[offset + --i]; - while (i > 0 && (mul *= 0x100)) { - val += this[offset + --i] * mul; - } - mul *= 0x80; - - if (val >= mul) val -= Math.pow(2, 8 * byteLength); - - return val -}; - -Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length); - if (!(this[offset] & 0x80)) return (this[offset]) - return ((0xff - this[offset] + 1) * -1) -}; - -Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - var val = this[offset] | (this[offset + 1] << 8); - return (val & 0x8000) ? val | 0xFFFF0000 : val -}; - -Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - var val = this[offset + 1] | (this[offset] << 8); - return (val & 0x8000) ? val | 0xFFFF0000 : val -}; - -Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16) | - (this[offset + 3] << 24) -}; - -Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset] << 24) | - (this[offset + 1] << 16) | - (this[offset + 2] << 8) | - (this[offset + 3]) -}; - -Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - return read(this, offset, true, 23, 4) -}; - -Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - return read(this, offset, false, 23, 4) -}; - -Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length); - return read(this, offset, true, 52, 8) -}; - -Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length); - return read(this, offset, false, 52, 8) -}; - -function checkInt (buf, value, offset, ext, max, min) { - if (!internalIsBuffer(buf)) throw new TypeError('"buffer" argument must be a Buffer instance') - if (value > max || value < min) throw new RangeError('"value" argument is out of bounds') - if (offset + ext > buf.length) throw new RangeError('Index out of range') -} - -Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - var maxBytes = Math.pow(2, 8 * byteLength) - 1; - checkInt(this, value, offset, byteLength, maxBytes, 0); - } - - var mul = 1; - var i = 0; - this[offset] = value & 0xFF; - while (++i < byteLength && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - var maxBytes = Math.pow(2, 8 * byteLength) - 1; - checkInt(this, value, offset, byteLength, maxBytes, 0); - } - - var i = byteLength - 1; - var mul = 1; - this[offset + i] = value & 0xFF; - while (--i >= 0 && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0); - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value); - this[offset] = (value & 0xff); - return offset + 1 -}; - -function objectWriteUInt16 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffff + value + 1; - for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) { - buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>> - (littleEndian ? i : 1 - i) * 8; - } -} - -Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - } else { - objectWriteUInt16(this, value, offset, true); - } - return offset + 2 -}; - -Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8); - this[offset + 1] = (value & 0xff); - } else { - objectWriteUInt16(this, value, offset, false); - } - return offset + 2 -}; - -function objectWriteUInt32 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffffffff + value + 1; - for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) { - buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff; - } -} - -Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset + 3] = (value >>> 24); - this[offset + 2] = (value >>> 16); - this[offset + 1] = (value >>> 8); - this[offset] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, true); - } - return offset + 4 -}; - -Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24); - this[offset + 1] = (value >>> 16); - this[offset + 2] = (value >>> 8); - this[offset + 3] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, false); - } - return offset + 4 -}; - -Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1); - - checkInt(this, value, offset, byteLength, limit - 1, -limit); - } - - var i = 0; - var mul = 1; - var sub = 0; - this[offset] = value & 0xFF; - while (++i < byteLength && (mul *= 0x100)) { - if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) { - sub = 1; - } - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1); - - checkInt(this, value, offset, byteLength, limit - 1, -limit); - } - - var i = byteLength - 1; - var mul = 1; - var sub = 0; - this[offset + i] = value & 0xFF; - while (--i >= 0 && (mul *= 0x100)) { - if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) { - sub = 1; - } - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80); - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value); - if (value < 0) value = 0xff + value + 1; - this[offset] = (value & 0xff); - return offset + 1 -}; - -Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - } else { - objectWriteUInt16(this, value, offset, true); - } - return offset + 2 -}; - -Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8); - this[offset + 1] = (value & 0xff); - } else { - objectWriteUInt16(this, value, offset, false); - } - return offset + 2 -}; - -Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - this[offset + 2] = (value >>> 16); - this[offset + 3] = (value >>> 24); - } else { - objectWriteUInt32(this, value, offset, true); - } - return offset + 4 -}; - -Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000); - if (value < 0) value = 0xffffffff + value + 1; - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24); - this[offset + 1] = (value >>> 16); - this[offset + 2] = (value >>> 8); - this[offset + 3] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, false); - } - return offset + 4 -}; - -function checkIEEE754 (buf, value, offset, ext, max, min) { - if (offset + ext > buf.length) throw new RangeError('Index out of range') - if (offset < 0) throw new RangeError('Index out of range') -} - -function writeFloat (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 4); - } - write(buf, value, offset, littleEndian, 23, 4); - return offset + 4 -} - -Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { - return writeFloat(this, value, offset, true, noAssert) -}; - -Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { - return writeFloat(this, value, offset, false, noAssert) -}; - -function writeDouble (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 8); - } - write(buf, value, offset, littleEndian, 52, 8); - return offset + 8 -} - -Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { - return writeDouble(this, value, offset, true, noAssert) -}; - -Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { - return writeDouble(this, value, offset, false, noAssert) -}; - -// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) -Buffer.prototype.copy = function copy (target, targetStart, start, end) { - if (!start) start = 0; - if (!end && end !== 0) end = this.length; - if (targetStart >= target.length) targetStart = target.length; - if (!targetStart) targetStart = 0; - if (end > 0 && end < start) end = start; - - // Copy 0 bytes; we're done - if (end === start) return 0 - if (target.length === 0 || this.length === 0) return 0 - - // Fatal error conditions - if (targetStart < 0) { - throw new RangeError('targetStart out of bounds') - } - if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds') - if (end < 0) throw new RangeError('sourceEnd out of bounds') - - // Are we oob? - if (end > this.length) end = this.length; - if (target.length - targetStart < end - start) { - end = target.length - targetStart + start; - } - - var len = end - start; - var i; - - if (this === target && start < targetStart && targetStart < end) { - // descending copy from end - for (i = len - 1; i >= 0; --i) { - target[i + targetStart] = this[i + start]; - } - } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) { - // ascending copy from start - for (i = 0; i < len; ++i) { - target[i + targetStart] = this[i + start]; - } - } else { - Uint8Array.prototype.set.call( - target, - this.subarray(start, start + len), - targetStart - ); - } - - return len -}; - -// Usage: -// buffer.fill(number[, offset[, end]]) -// buffer.fill(buffer[, offset[, end]]) -// buffer.fill(string[, offset[, end]][, encoding]) -Buffer.prototype.fill = function fill (val, start, end, encoding) { - // Handle string cases: - if (typeof val === 'string') { - if (typeof start === 'string') { - encoding = start; - start = 0; - end = this.length; - } else if (typeof end === 'string') { - encoding = end; - end = this.length; - } - if (val.length === 1) { - var code = val.charCodeAt(0); - if (code < 256) { - val = code; - } - } - if (encoding !== undefined && typeof encoding !== 'string') { - throw new TypeError('encoding must be a string') - } - if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) { - throw new TypeError('Unknown encoding: ' + encoding) - } - } else if (typeof val === 'number') { - val = val & 255; - } - - // Invalid ranges are not set to a default, so can range check early. - if (start < 0 || this.length < start || this.length < end) { - throw new RangeError('Out of range index') - } - - if (end <= start) { - return this - } - - start = start >>> 0; - end = end === undefined ? this.length : end >>> 0; - - if (!val) val = 0; - - var i; - if (typeof val === 'number') { - for (i = start; i < end; ++i) { - this[i] = val; - } - } else { - var bytes = internalIsBuffer(val) - ? val - : utf8ToBytes(new Buffer(val, encoding).toString()); - var len = bytes.length; - for (i = 0; i < end - start; ++i) { - this[i + start] = bytes[i % len]; - } - } - - return this -}; - -// HELPER FUNCTIONS -// ================ - -var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g; - -function base64clean (str) { - // Node strips out invalid characters like \n and \t from the string, base64-js does not - str = stringtrim(str).replace(INVALID_BASE64_RE, ''); - // Node converts strings with length < 2 to '' - if (str.length < 2) return '' - // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not - while (str.length % 4 !== 0) { - str = str + '='; - } - return str -} - -function stringtrim (str) { - if (str.trim) return str.trim() - return str.replace(/^\s+|\s+$/g, '') -} - -function toHex (n) { - if (n < 16) return '0' + n.toString(16) - return n.toString(16) -} - -function utf8ToBytes (string, units) { - units = units || Infinity; - var codePoint; - var length = string.length; - var leadSurrogate = null; - var bytes = []; - - for (var i = 0; i < length; ++i) { - codePoint = string.charCodeAt(i); - - // is surrogate component - if (codePoint > 0xD7FF && codePoint < 0xE000) { - // last char was a lead - if (!leadSurrogate) { - // no lead yet - if (codePoint > 0xDBFF) { - // unexpected trail - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - continue - } else if (i + 1 === length) { - // unpaired lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - continue - } - - // valid lead - leadSurrogate = codePoint; - - continue - } - - // 2 leads in a row - if (codePoint < 0xDC00) { - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - leadSurrogate = codePoint; - continue - } - - // valid surrogate pair - codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000; - } else if (leadSurrogate) { - // valid bmp char, but last char was a lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - } - - leadSurrogate = null; - - // encode utf8 - if (codePoint < 0x80) { - if ((units -= 1) < 0) break - bytes.push(codePoint); - } else if (codePoint < 0x800) { - if ((units -= 2) < 0) break - bytes.push( - codePoint >> 0x6 | 0xC0, - codePoint & 0x3F | 0x80 - ); - } else if (codePoint < 0x10000) { - if ((units -= 3) < 0) break - bytes.push( - codePoint >> 0xC | 0xE0, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ); - } else if (codePoint < 0x110000) { - if ((units -= 4) < 0) break - bytes.push( - codePoint >> 0x12 | 0xF0, - codePoint >> 0xC & 0x3F | 0x80, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ); - } else { - throw new Error('Invalid code point') - } - } - - return bytes -} - -function asciiToBytes (str) { - var byteArray = []; - for (var i = 0; i < str.length; ++i) { - // Node's code seems to be doing this and not & 0x7F.. - byteArray.push(str.charCodeAt(i) & 0xFF); - } - return byteArray -} - -function utf16leToBytes (str, units) { - var c, hi, lo; - var byteArray = []; - for (var i = 0; i < str.length; ++i) { - if ((units -= 2) < 0) break - - c = str.charCodeAt(i); - hi = c >> 8; - lo = c % 256; - byteArray.push(lo); - byteArray.push(hi); - } - - return byteArray -} - - -function base64ToBytes (str) { - return toByteArray(base64clean(str)) -} - -function blitBuffer (src, dst, offset, length) { - for (var i = 0; i < length; ++i) { - if ((i + offset >= dst.length) || (i >= src.length)) break - dst[i + offset] = src[i]; - } - return i -} - -function isnan (val) { - return val !== val // eslint-disable-line no-self-compare -} - - -// the following is from is-buffer, also by Feross Aboukhadijeh and with same lisence -// The _isBuffer check is for Safari 5-7 support, because it's missing -// Object.prototype.constructor. Remove this eventually -function isBuffer(obj) { - return obj != null && (!!obj._isBuffer || isFastBuffer(obj) || isSlowBuffer(obj)) -} - -function isFastBuffer (obj) { - return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj) -} - -// For Node v0.10 support. Remove this eventually. -function isSlowBuffer (obj) { - return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isFastBuffer(obj.slice(0, 0)) -} - -// Copyright Joyent, Inc. and other Node contributors. -var isBufferEncoding = Buffer.isEncoding - || function(encoding) { - switch (encoding && encoding.toLowerCase()) { - case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true; - default: return false; - } - }; - - -function assertEncoding(encoding) { - if (encoding && !isBufferEncoding(encoding)) { - throw new Error('Unknown encoding: ' + encoding); - } -} - -// StringDecoder provides an interface for efficiently splitting a series of -// buffers into a series of JS strings without breaking apart multi-byte -// characters. CESU-8 is handled as part of the UTF-8 encoding. -// -// @TODO Handling all encodings inside a single object makes it very difficult -// to reason about this code, so it should be split up in the future. -// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code -// points as used by CESU-8. -function StringDecoder(encoding) { - this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, ''); - assertEncoding(encoding); - switch (this.encoding) { - case 'utf8': - // CESU-8 represents each of Surrogate Pair by 3-bytes - this.surrogateSize = 3; - break; - case 'ucs2': - case 'utf16le': - // UTF-16 represents each of Surrogate Pair by 2-bytes - this.surrogateSize = 2; - this.detectIncompleteChar = utf16DetectIncompleteChar; - break; - case 'base64': - // Base-64 stores 3 bytes in 4 chars, and pads the remainder. - this.surrogateSize = 3; - this.detectIncompleteChar = base64DetectIncompleteChar; - break; - default: - this.write = passThroughWrite; - return; - } - - // Enough space to store all bytes of a single character. UTF-8 needs 4 - // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate). - this.charBuffer = new Buffer(6); - // Number of bytes received for the current incomplete multi-byte character. - this.charReceived = 0; - // Number of bytes expected for the current incomplete multi-byte character. - this.charLength = 0; -} - -// write decodes the given buffer and returns it as JS string that is -// guaranteed to not contain any partial multi-byte characters. Any partial -// character found at the end of the buffer is buffered up, and will be -// returned when calling write again with the remaining bytes. -// -// Note: Converting a Buffer containing an orphan surrogate to a String -// currently works, but converting a String to a Buffer (via `new Buffer`, or -// Buffer#write) will replace incomplete surrogates with the unicode -// replacement character. See https://codereview.chromium.org/121173009/ . -StringDecoder.prototype.write = function(buffer) { - var charStr = ''; - // if our last write ended with an incomplete multibyte character - while (this.charLength) { - // determine how many remaining bytes this buffer has to offer for this char - var available = (buffer.length >= this.charLength - this.charReceived) ? - this.charLength - this.charReceived : - buffer.length; - - // add the new bytes to the char buffer - buffer.copy(this.charBuffer, this.charReceived, 0, available); - this.charReceived += available; - - if (this.charReceived < this.charLength) { - // still not enough chars in this buffer? wait for more ... - return ''; - } - - // remove bytes belonging to the current character from the buffer - buffer = buffer.slice(available, buffer.length); - - // get the character that was split - charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding); - - // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character - var charCode = charStr.charCodeAt(charStr.length - 1); - if (charCode >= 0xD800 && charCode <= 0xDBFF) { - this.charLength += this.surrogateSize; - charStr = ''; - continue; - } - this.charReceived = this.charLength = 0; - - // if there are no more bytes in this buffer, just emit our char - if (buffer.length === 0) { - return charStr; - } - break; - } - - // determine and set charLength / charReceived - this.detectIncompleteChar(buffer); - - var end = buffer.length; - if (this.charLength) { - // buffer the incomplete character bytes we got - buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end); - end -= this.charReceived; - } - - charStr += buffer.toString(this.encoding, 0, end); - - var end = charStr.length - 1; - var charCode = charStr.charCodeAt(end); - // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character - if (charCode >= 0xD800 && charCode <= 0xDBFF) { - var size = this.surrogateSize; - this.charLength += size; - this.charReceived += size; - this.charBuffer.copy(this.charBuffer, size, 0, size); - buffer.copy(this.charBuffer, 0, 0, size); - return charStr.substring(0, end); - } - - // or just emit the charStr - return charStr; -}; - -// detectIncompleteChar determines if there is an incomplete UTF-8 character at -// the end of the given buffer. If so, it sets this.charLength to the byte -// length that character, and sets this.charReceived to the number of bytes -// that are available for this character. -StringDecoder.prototype.detectIncompleteChar = function(buffer) { - // determine how many bytes we have to check at the end of this buffer - var i = (buffer.length >= 3) ? 3 : buffer.length; - - // Figure out if one of the last i bytes of our buffer announces an - // incomplete char. - for (; i > 0; i--) { - var c = buffer[buffer.length - i]; - - // See http://en.wikipedia.org/wiki/UTF-8#Description - - // 110XXXXX - if (i == 1 && c >> 5 == 0x06) { - this.charLength = 2; - break; - } - - // 1110XXXX - if (i <= 2 && c >> 4 == 0x0E) { - this.charLength = 3; - break; - } - - // 11110XXX - if (i <= 3 && c >> 3 == 0x1E) { - this.charLength = 4; - break; - } - } - this.charReceived = i; -}; - -StringDecoder.prototype.end = function(buffer) { - var res = ''; - if (buffer && buffer.length) - res = this.write(buffer); - - if (this.charReceived) { - var cr = this.charReceived; - var buf = this.charBuffer; - var enc = this.encoding; - res += buf.slice(0, cr).toString(enc); - } - - return res; -}; - -function passThroughWrite(buffer) { - return buffer.toString(this.encoding); -} - -function utf16DetectIncompleteChar(buffer) { - this.charReceived = buffer.length % 2; - this.charLength = this.charReceived ? 2 : 0; -} - -function base64DetectIncompleteChar(buffer) { - this.charReceived = buffer.length % 3; - this.charLength = this.charReceived ? 3 : 0; -} - -const BUFFER_MAX_BYTES = 524288; // 0.5Mb - -const CONTINUE_READING_RECORDS = "CONTINUE_READING"; -const READ_REMAINING_TEXT = "READ_REMAINING"; -const CANCEL_READ = "CANCEL"; - -const getIndexWriter = (hierarchy, indexNode, readableStream, writableStream, end) => { - const schema = generateSchema(hierarchy, indexNode); - - return ({ - read: read$1(readableStream, schema), - updateIndex: updateIndex(readableStream, writableStream, schema) - }); -}; - -const getIndexReader = (hierarchy, indexNode, readableStream) => - read$1( - readableStream, - generateSchema(hierarchy, indexNode) - ); - -const updateIndex = (readableStream, writableStream, schema) => async (itemsToWrite, keysToRemove) => { - const write = newOutputWriter(BUFFER_MAX_BYTES, writableStream); - const writtenItems = []; - await read$1(readableStream, schema)( - async indexedItem => { - const updated = fp.find(i => indexedItem.key === i.key)(itemsToWrite); - const removed = fp.find(k => indexedItem.key === k)(keysToRemove); - - if(isSomething(removed)) - return CONTINUE_READING_RECORDS; - - if(isSomething(updated)) { - const serializedItem = serializeItem(schema, updated); - await write(serializedItem); - writtenItems.push(updated); - } else { - await write( - serializeItem(schema, indexedItem) - ); - } - - return CONTINUE_READING_RECORDS; - - }, - async text => await write(text) - ); - - if(writtenItems.length !== itemsToWrite.length) { - const toAdd = fp.difference(itemsToWrite, writtenItems); - for(let added of toAdd) { - await write( - serializeItem(schema, added) - ); - } - } else if(writtenItems.length === 0) { - // potentially are no records - await write(""); - } - - await write(); - await writableStream.end(); -}; - -const read$1 = (readableStream, schema) => async (onGetItem, onGetText) => { - const readInput = newInputReader(readableStream); - let text = await readInput(); - let status = CONTINUE_READING_RECORDS; - while(text.length > 0) { - - if(status === READ_REMAINING_TEXT) { - await onGetText(text); - continue; - } - - if(status === CANCEL_READ) { - return; - } - - let rowText = ""; - let currentCharIndex=0; - for(let currentChar of text) { - rowText += currentChar; - if(currentChar === "\r") { - status = await onGetItem( - deserializeRow(schema, rowText) - ); - rowText = ""; - if(status === READ_REMAINING_TEXT) { - break; - } - } - currentCharIndex++; - } - - if(currentCharIndex < text.length -1) { - await onGetText(text.substring(currentCharIndex + 1)); - } - - text = await readInput(); - } - - await readableStream.destroy(); - -}; - -const newOutputWriter = (flushBoundary, writableStream) => { - - let currentBuffer = null; - - return async (text) => { - - if(fp.isString(text) && currentBuffer === null) - currentBuffer = safeBuffer.Buffer.from(text, "utf8"); - else if(fp.isString(text)) - currentBuffer = safeBuffer.Buffer.concat([ - currentBuffer, - safeBuffer.Buffer.from(text, "utf8") - ]); - - if(currentBuffer !== null && - (currentBuffer.length > flushBoundary - || !fp.isString(text))) { - - await writableStream.write(currentBuffer); - currentBuffer = null; - } - } -}; - -const newInputReader = (readableStream) => { - - const decoder = new StringDecoder('utf8'); - let remainingBytes = []; - - return async () => { - - let nextBytesBuffer = await readableStream.read(BUFFER_MAX_BYTES); - const remainingBuffer = safeBuffer.Buffer.from(remainingBytes); - - if(!nextBytesBuffer) nextBytesBuffer = safeBuffer.Buffer.from([]); - - const moreToRead = nextBytesBuffer.length === BUFFER_MAX_BYTES; - - const buffer = safeBuffer.Buffer.concat( - [remainingBuffer, nextBytesBuffer], - remainingBuffer.length + nextBytesBuffer.length); - - const text = decoder.write(buffer); - remainingBytes = decoder.end(buffer); - - if(!moreToRead && remainingBytes.length > 0) { - // if for any reason, we have remaining bytes at the end - // of the stream, just discard - dont see why this should - // ever happen, but if it does, it could cause a stack overflow - remainingBytes = []; - } - - return text; - }; -}; - -const deserializeRow = (schema, rowText) => { - let currentPropIndex = 0; - let currentCharIndex = 0; - let currentValueText = ""; - let isEscaped = false; - const item = {}; - - const setCurrentProp = () => { - const currentProp = schema[currentPropIndex]; - const type = getType(currentProp.type); - const value = currentValueText === "" - ? type.getDefaultValue() - : type.safeParseValue( - currentValueText); - item[currentProp.name] = value; - }; - - while(currentPropIndex < schema.length) { - - if(currentCharIndex < rowText.length) { - const currentChar = rowText[currentCharIndex]; - if(isEscaped) { - if(currentChar === "r") { - currentValueText += "\r"; - } else { - currentValueText += currentChar; - } - isEscaped = false; - } else { - if(currentChar === ",") { - setCurrentProp(); - currentValueText = ""; - currentPropIndex++; - } else if(currentChar === "\\") { - isEscaped = true; - } else { - currentValueText += currentChar; - } - } - currentCharIndex++; - } else { - currentValueText = ""; - setCurrentProp(); - currentPropIndex++; - } - } - - return item; -}; - -const serializeItem = (schema, item) => { - - let rowText = ""; - - for(let prop of schema) { - const type = getType(prop.type); - const value = fp.has(prop.name)(item) - ? item[prop.name] - : type.getDefaultValue(); - - const valStr = type.stringify(value); - - for(let i = 0; i < valStr.length; i++) { - const currentChar = valStr[i]; - if(currentChar === "," - || currentChar === "\r" - || currentChar === "\\") { - rowText += "\\"; - } - - if(currentChar === "\r") { - rowText += "r"; - } else { - rowText += currentChar; - } - } - - rowText += ","; - } - - rowText += "\r"; - return rowText; -}; - -const readIndex$1 = async (hierarchy, datastore, index, indexedDataKey) => { - const records = []; - const doRead = iterateIndex( - async item => { - records.push(item); - return CONTINUE_READING_RECORDS; - }, - async () => records - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); -}; - -const searchIndex = async (hierarchy, datastore, index, indexedDataKey, searchPhrase) => { - const records = []; - const schema = generateSchema(hierarchy, index); - const doRead = iterateIndex( - async item => { - const idx = lunr(function () { - this.ref('key'); - for (const field of schema) { - this.field(field.name); - } - this.add(item); - }); - const searchResults = idx.search(searchPhrase); - if (searchResults.length === 1) { - item._searchResult = searchResults[0]; - records.push(item); - } - return CONTINUE_READING_RECORDS; - }, - async () => records - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); -}; - -const iterateIndex = (onGetItem, getFinalResult) => async (hierarchy, datastore, index, indexedDataKey) => { - try { - const readableStream = promiseReadableStream( - await datastore.readableFileStream(indexedDataKey) - ); - - const read = getIndexReader(hierarchy, index, readableStream); - await read(onGetItem); - return getFinalResult(); - } catch (e) { - if (await datastore.exists(indexedDataKey)) { - throw e; - } else { - await createIndexFile( - datastore, - indexedDataKey, - index, - ); - } - return []; - } -}; - -const getIndexDir = (hierarchy, indexKey) => { - - const parentKey = getParentKey(indexKey); - - if(parentKey === "") return indexKey; - if(parentKey === keySep) return indexKey; - - const recordInfo = getRecordInfo( - hierarchy, - parentKey); - - return recordInfo.child( - getLastPartInKey(indexKey)); -}; - -const listItems = app => async (indexKey, options) => { - indexKey = safeKey(indexKey); - return apiWrapper( - app, - events.indexApi.listItems, - permission.readIndex.isAuthorized(indexKey), - { indexKey, options }, - _listItems, app, indexKey, options, - ); -}; - -const defaultOptions = { rangeStartParams: null, rangeEndParams: null, searchPhrase: null }; - -const _listItems = async (app, indexKey, options = defaultOptions) => { - const { searchPhrase, rangeStartParams, rangeEndParams } = $({}, [ - fp.merge(options), - fp.merge(defaultOptions), - ]); - - const getItems = async indexedDataKey => (isNonEmptyString(searchPhrase) - ? await searchIndex( - app.hierarchy, - app.datastore, - indexNode, - indexedDataKey, - searchPhrase, - ) - : await readIndex$1( - app.hierarchy, - app.datastore, - indexNode, - indexedDataKey, - )); - - indexKey = safeKey(indexKey); - const indexNode = getExactNodeForKey(app.hierarchy)(indexKey); - const indexDir = getIndexDir(app.hierarchy, indexKey); - - if (!isIndex(indexNode)) { throw new Error('supplied key is not an index'); } - - if (isShardedIndex(indexNode)) { - const shardKeys = await getShardKeysInRange( - app, indexNode, indexDir, rangeStartParams, rangeEndParams, - ); - const items = []; - for (const k of shardKeys) { - items.push(await getItems(k)); - } - return fp.flatten(items); - } - return await getItems( - getUnshardedIndexDataKey(indexDir), - ); -}; - -const getContext = app => recordKey => { - recordKey = safeKey(recordKey); - return apiWrapperSync( - app, - events.recordApi.getContext, - permission.readRecord.isAuthorized(recordKey), - { recordKey }, - _getContext, app, recordKey, - ); -}; - -const _getContext = (app, recordKey) => { - recordKey = safeKey(recordKey); - const recordNode = getExactNodeForKey(app.hierarchy)(recordKey); - - const cachedReferenceIndexes = {}; - - const lazyLoadReferenceIndex = async (typeOptions) => { - if (!fp.has(typeOptions.indexNodeKey)(cachedReferenceIndexes)) { - cachedReferenceIndexes[typeOptions.indexNodeKey] = { - typeOptions, - data: await readReferenceIndex( - app, recordKey, typeOptions, - ), - }; - } - - return cachedReferenceIndexes[typeOptions.indexNodeKey]; - }; - - const getTypeOptions = typeOptions_or_fieldName => (fp.isString(typeOptions_or_fieldName) - ? findField(recordNode, typeOptions_or_fieldName) - .typeOptions - : typeOptions_or_fieldName); - - return { - referenceExists: async (typeOptions_or_fieldName, key) => { - const typeOptions = getTypeOptions(typeOptions_or_fieldName); - const { data } = await lazyLoadReferenceIndex(typeOptions); - return fp.some(i => i.key === key)(data); - }, - referenceOptions: async (typeOptions_or_fieldName) => { - const typeOptions = getTypeOptions(typeOptions_or_fieldName); - const { data } = await lazyLoadReferenceIndex(typeOptions); - return data; - }, - recordNode, - }; -}; - -const readReferenceIndex = async (app, recordKey, typeOptions) => { - const indexNode = getNode(app.hierarchy, typeOptions.indexNodeKey); - const indexKey = isGlobalIndex(indexNode) - ? indexNode.nodeKey() - : getIndexKey_BasedOnDecendant( - recordKey, indexNode, - ); - - const items = await listItems(app)(indexKey); - return $(items, [ - fp.map(i => ({ - key: i.key, - value: i[typeOptions.displayValue], - })), - ]); -}; - -const fieldParseError = (fieldName, value) => ({ - fields: [fieldName], - message: `Could not parse field ${fieldName}:${value}`, -}); - -const validateAllFieldParse = (record, recordNode) => $(recordNode.fields, [ - fp.map(f => ({ name: f.name, parseResult: validateFieldParse(f, record) })), - fp.reduce((errors, f) => { - if (f.parseResult.success) return errors; - errors.push( - fieldParseError(f.name, f.parseResult.value), - ); - return errors; - }, []), -]); - -const validateAllTypeConstraints = async (record, recordNode, context) => { - const errors = []; - for (const field of recordNode.fields) { - $(await validateTypeConstraints$1(field, record, context), [ - fp.filter(isNonEmptyString), - fp.map(m => ({ message: m, fields: [field.name] })), - fp.each(e => errors.push(e)), - ]); - } - return errors; -}; - -const runRecordValidationRules = (record, recordNode) => { - const runValidationRule = (rule) => { - const isValid = compilerUtil.compileExpression(rule.expressionWhenValid); - const expressionContext = { record, _: ___default }; - return (isValid(expressionContext) - ? { valid: true } - : ({ - valid: false, - fields: rule.invalidFields, - message: rule.messageWhenInvalid, - })); - }; - - return $(recordNode.validationRules, [ - fp.map(runValidationRule), - fp.flatten, - fp.filter(r => r.valid === false), - fp.map(r => ({ fields: r.fields, message: r.message })), - ]); -}; - -const validate = app => async (record, context) => { - context = isNothing(context) - ? _getContext(app, record.key) - : context; - - const recordNode = getExactNodeForKey(app.hierarchy)(record.key); - const fieldParseFails = validateAllFieldParse(record, recordNode); - - // non parsing would cause further issues - exit here - if (!fp.isEmpty(fieldParseFails)) { return ({ isValid: false, errors: fieldParseFails }); } - - const recordValidationRuleFails = runRecordValidationRules(record, recordNode); - const typeContraintFails = await validateAllTypeConstraints(record, recordNode, context); - - if (fp.isEmpty(fieldParseFails) - && fp.isEmpty(recordValidationRuleFails) - && fp.isEmpty(typeContraintFails)) { - return ({ isValid: true, errors: [] }); - } - - return ({ - isValid: false, - errors: ___default.union(fieldParseFails, typeContraintFails, recordValidationRuleFails), - }); -}; - -const ensureCollectionIsInitialised = async (datastore, node, dir) => { - if (!await datastore.exists(dir)) { - await datastore.createFolder(dir); - await datastore.createFolder(joinKey(dir, node.nodeId)); - } -}; - -const initialiseRootCollections = async (datastore, hierarchy) => { - const rootCollectionRecord = allTrue( - n => isRoot(n.parent()), - isCollectionRecord, - ); - - const flathierarchy = getFlattenedHierarchy(hierarchy); - - const collectionRecords = $(flathierarchy, [ - fp.filter(rootCollectionRecord), - ]); - - for (const col of collectionRecords) { - await ensureCollectionIsInitialised( - datastore, - col, - col.collectionPathRegx() - ); - } -}; - -const initialiseChildCollections = async (app, recordInfo) => { - const childCollectionRecords = $(recordInfo.recordNode, [ - n => n.children, - fp.filter(isCollectionRecord), - ]); - - for (const child of childCollectionRecords) { - await ensureCollectionIsInitialised( - app.datastore, - child, - recordInfo.child(child.collectionName), - ); - } -}; - -const TRANSACTIONS_FOLDER = `${keySep}.transactions`; -const LOCK_FILENAME = 'lock'; -const LOCK_FILE_KEY = joinKey( - TRANSACTIONS_FOLDER, LOCK_FILENAME, -); -const idSep = '$'; - -const isOfType = typ => trans => trans.transactionType === typ; - -const CREATE_RECORD_TRANSACTION = 'create'; -const UPDATE_RECORD_TRANSACTION = 'update'; -const DELETE_RECORD_TRANSACTION = 'delete'; -const BUILD_INDEX_TRANSACTION = 'build'; - -const isUpdate = isOfType(UPDATE_RECORD_TRANSACTION); -const isDelete = isOfType(DELETE_RECORD_TRANSACTION); -const isCreate = isOfType(CREATE_RECORD_TRANSACTION); -const isBuildIndex = isOfType(BUILD_INDEX_TRANSACTION); - -const keyToFolderName = nodeKey => getHashCode(nodeKey); - -const getTransactionId = (recordId, transactionType, uniqueId) => - `${recordId}${idSep}${transactionType}${idSep}${uniqueId}`; - -const buildIndexFolder = '.BUILD-'; -const nodeKeyHashFromBuildFolder = folder => folder.replace(buildIndexFolder, ''); - -const isBuildIndexFolder = key => getLastPartInKey(key).startsWith(buildIndexFolder); - -const IndexNodeKeyFolder = indexNodeKey => joinKey( - TRANSACTIONS_FOLDER, - buildIndexFolder + keyToFolderName(indexNodeKey), -); - -const IndexNodeKeyBatchFolder = (indexNodeKey, count) => - joinKey(IndexNodeKeyFolder(indexNodeKey), Math.floor(count / BUILDINDEX_BATCH_COUNT).toString()); - -const BUILDINDEX_BATCH_COUNT = 1000; -const timeoutMilliseconds = 30 * 1000; // 30 secs -const maxLockRetries = 1; - -const transactionForCreateRecord = async (app, record) => await transaction( - app.datastore, CREATE_RECORD_TRANSACTION, - record.key, { record }, - getTransactionKey_Records, -); - -const transactionForUpdateRecord = async (app, oldRecord, newRecord) => await transaction( - app.datastore, UPDATE_RECORD_TRANSACTION, - newRecord.key, { oldRecord, record: newRecord }, - getTransactionKey_Records, -); - -const transactionForDeleteRecord = async (app, record) => await transaction( - app.datastore, DELETE_RECORD_TRANSACTION, - record.key, { record }, - getTransactionKey_Records, -); - -const transactionForBuildIndex = async (app, indexNodeKey, recordKey, count) => { - const transactionFolder = IndexNodeKeyBatchFolder(indexNodeKey, count); - if (count % BUILDINDEX_BATCH_COUNT === 0) { - await app.datastore.createFolder(transactionFolder); - } - - return await transaction( - app.datastore, BUILD_INDEX_TRANSACTION, - recordKey, { recordKey }, - id => joinKey(transactionFolder, id), - ); -}; - -const createBuildIndexFolder = async (datastore, indexNodeKey) => await datastore.createFolder( - IndexNodeKeyFolder(indexNodeKey), -); - -const getTransactionKey_Records = id => joinKey(TRANSACTIONS_FOLDER, id); - -const transaction = async (datastore, transactionType, recordKey, data, getTransactionKey) => { - const recordId = getLastPartInKey(recordKey); - const uniqueId = shortid.generate(); - const id = getTransactionId( - recordId, transactionType, uniqueId, - ); - - const key = getTransactionKey(id); - - const trans = { - transactionType, - recordKey, - ...data, - id, - }; - - await datastore.createJson( - key, trans, - ); - - return trans; -}; - -const initialiseIndex = async (datastore, dir, index) => { - const indexDir = joinKey(dir, index.name); - - await datastore.createFolder(indexDir); - - if (isShardedIndex(index)) { - await datastore.createFile( - getShardMapKey(indexDir), - '[]', - ); - } else { - await createIndexFile( - datastore, - getUnshardedIndexDataKey(indexDir), - index, - ); - } -}; - -const save = app => async (record, context) => apiWrapper( - app, - events.recordApi.save, - record.isNew - ? permission.createRecord.isAuthorized(record.key) - : permission.updateRecord.isAuthorized(record.key), { record }, - _save, app, record, context, false, -); - - -const _save = async (app, record, context, skipValidation = false) => { - const recordClone = fp.cloneDeep(record); - if (!skipValidation) { - const validationResult = await validate(app)(recordClone, context); - if (!validationResult.isValid) { - await app.publish(events.recordApi.save.onInvalid, { record, validationResult }); - throw new BadRequestError(`Save : Record Invalid : ${ - JSON.stringify(validationResult.errors)}`); - } - } - - const recordInfo = getRecordInfo(app.hierarchy, record.key); - const { - recordNode, pathInfo, - recordJson, files, - } = recordInfo; - - if (recordClone.isNew) { - - if(!recordNode) - throw new Error("Cannot find node for " + record.key); - - const transaction = await transactionForCreateRecord( - app, recordClone, - ); - recordClone.transactionId = transaction.id; - await createRecordFolderPath(app.datastore, pathInfo); - await app.datastore.createFolder(files); - await app.datastore.createJson(recordJson, recordClone); - await initialiseReverseReferenceIndexes(app, recordInfo); - await initialiseAncestorIndexes(app, recordInfo); - await initialiseChildCollections(app, recordInfo); - await app.publish(events.recordApi.save.onRecordCreated, { - record: recordClone, - }); - } else { - const oldRecord = await _loadFromInfo(app, recordInfo); - const transaction = await transactionForUpdateRecord( - app, oldRecord, recordClone, - ); - recordClone.transactionId = transaction.id; - await app.datastore.updateJson( - recordJson, - recordClone, - ); - await app.publish(events.recordApi.save.onRecordUpdated, { - old: oldRecord, - new: recordClone, - }); - } - - await app.cleanupTransactions(); - - const returnedClone = fp.cloneDeep(recordClone); - returnedClone.isNew = false; - return returnedClone; -}; - -const initialiseAncestorIndexes = async (app, recordInfo) => { - for (const index of recordInfo.recordNode.indexes) { - const indexKey = recordInfo.child(index.name); - if (!await app.datastore.exists(indexKey)) { - await initialiseIndex(app.datastore, recordInfo.dir, index); - } - } -}; - -const initialiseReverseReferenceIndexes = async (app, recordInfo) => { - - const indexNodes = $(fieldsThatReferenceThisRecord(app, recordInfo.recordNode), [ - fp.map(f => $(f.typeOptions.reverseIndexNodeKeys, [ - fp.map(n => getNode( - app.hierarchy, - n, - )), - ])), - fp.flatten, - ]); - - for (const indexNode of indexNodes) { - await initialiseIndex( - app.datastore, recordInfo.dir, indexNode, - ); - } -}; - -const fieldsThatReferenceThisRecord = (app, recordNode) => $(app.hierarchy, [ - getFlattenedHierarchy, - fp.filter(isRecord), - fp.map(n => n.fields), - fp.flatten, - fp.filter(fieldReversesReferenceToNode(recordNode)), -]); - -const createRecordFolderPath = async (datastore, pathInfo) => { - - const recursiveCreateFolder = async (subdirs, dirsThatNeedCreated=undefined) => { - - // iterate backwards through directory hierachy - // until we get to a folder that exists, then create the rest - // e.g - // - some/folder/here - // - some/folder - // - some - const thisFolder = joinKey(pathInfo.base, ...subdirs); - - if(await datastore.exists(thisFolder)) { - - let creationFolder = thisFolder; - for(let nextDir of (dirsThatNeedCreated || []) ) { - creationFolder = joinKey(creationFolder, nextDir); - await datastore.createFolder(creationFolder); - } - - } else if(!dirsThatNeedCreated || dirsThatNeedCreated.length > 0) { - - dirsThatNeedCreated = !dirsThatNeedCreated - ? [] - :dirsThatNeedCreated; - - await recursiveCreateFolder( - fp.take(subdirs.length - 1)(subdirs), - [...fp.takeRight(1)(subdirs), ...dirsThatNeedCreated] - ); - } - }; - - await recursiveCreateFolder(pathInfo.subdirs); - - return joinKey(pathInfo.base, ...pathInfo.subdirs); - -}; - -const deleteCollection = (app, disableCleanup = false) => async key => apiWrapper( - app, - events.collectionApi.delete, - permission.manageCollection.isAuthorized, - { key }, - _deleteCollection, app, key, disableCleanup, -); - -/* - const recordNode = getCollectionNode(app.hierarchy, key); - -*/ - -const _deleteCollection = async (app, key, disableCleanup) => { - key = safeKey(key); - const collectionDir = getCollectionDir(app.hierarchy, key); - await deleteRecords(app, key); - await deleteCollectionFolder(app, collectionDir); - if (!disableCleanup) { await app.cleanupTransactions(); } -}; - -const deleteCollectionFolder = async (app, dir) => - await app.datastore.deleteFolder(dir); - -const deleteRecords = async (app, key) => { - - const iterate = await getAllIdsIterator(app)(key); - - let ids = await iterate(); - while (!ids.done) { - if (ids.result.collectionKey === key) { - for (const id of ids.result.ids) { - await _deleteRecord( - app, - joinKey(key, id), - true, - ); - } - } - - ids = await iterate(); - } -}; - -const deleteRecord$1 = (app, disableCleanup = false) => async key => { - key = safeKey(key); - return apiWrapper( - app, - events.recordApi.delete, - permission.deleteRecord.isAuthorized(key), - { key }, - _deleteRecord, app, key, disableCleanup, - ); -}; - -// called deleteRecord because delete is a keyword -const _deleteRecord = async (app, key, disableCleanup) => { - const recordInfo = getRecordInfo(app.hierarchy, key); - key = recordInfo.key; - const node = getExactNodeForKey(app.hierarchy)(key); - - const record = await _load(app, key); - await transactionForDeleteRecord(app, record); - - for (const collectionRecord of node.children) { - const collectionKey = joinKey( - key, collectionRecord.collectionName, - ); - await _deleteCollection(app, collectionKey, true); - } - - await app.datastore.deleteFolder(recordInfo.dir); - - if (!disableCleanup) { await app.cleanupTransactions(); } -}; - -const uploadFile = app => async (recordKey, readableStream, relativeFilePath) => apiWrapper( - app, - events.recordApi.uploadFile, - permission.updateRecord.isAuthorized(recordKey), - { recordKey, readableStream, relativeFilePath }, - _uploadFile, app, recordKey, readableStream, relativeFilePath, -); - -const _uploadFile = async (app, recordKey, readableStream, relativeFilePath) => { - if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); } - if (isNothing(relativeFilePath)) { throw new BadRequestError('file path not supplied'); } - if (!isLegalFilename(relativeFilePath)) { throw new BadRequestError('Illegal filename'); } - - const recordInfo = getRecordInfo(app.hierarchy, recordKey); - const record = await _loadFromInfo(app, recordInfo); - - const fullFilePath = safeGetFullFilePath( - recordInfo.dir, relativeFilePath, - ); - - const tempFilePath = `${fullFilePath}_${shortid.generate()}.temp`; - - const outputStream = await app.datastore.writableFileStream( - tempFilePath, - ); - - return new Promise((resolve,reject) => { - readableStream.pipe(outputStream); - outputStream.on('error', reject); - outputStream.on('finish', resolve); - }) - .then(() => app.datastore.getFileSize(tempFilePath)) - .then(size => { - const isExpectedFileSize = checkFileSizeAgainstFields( - app, record, relativeFilePath, size - ); - if (!isExpectedFileSize) { throw new BadRequestError(`Fields for ${relativeFilePath} do not have expected size: ${join(',')(incorrectFields)}`); } - - }) - .then(() => tryAwaitOrIgnore(app.datastore.deleteFile, fullFilePath)) - .then(() => app.datastore.renameFile(tempFilePath, fullFilePath)); - -}; - -const checkFileSizeAgainstFields = (app, record, relativeFilePath, expectedSize) => { - const recordNode = getExactNodeForKey(app.hierarchy)(record.key); - - const incorrectFileFields = $(recordNode.fields, [ - fp.filter(f => f.type === 'file' - && record[f.name].relativePath === relativeFilePath - && record[f.name].size !== expectedSize), - fp.map(f => f.name), - ]); - - const incorrectFileArrayFields = $(recordNode.fields, [ - fp.filter(a => a.type === 'array' - && $(record[a.name], [ - fp.some(f => record[f.name].relativePath === relativeFilePath - && record[f.name].size !== expectedSize), - ])), - fp.map(f => f.name), - ]); - - const incorrectFields = [ - ...incorrectFileFields, - ...incorrectFileArrayFields, - ]; - - if (incorrectFields.length > 0) { - return false; - } - - return true; -}; - -const safeGetFullFilePath = (recordDir, relativeFilePath) => { - const naughtyUser = () => { throw new ForbiddenError('naughty naughty'); }; - - if (relativeFilePath.startsWith('..')) naughtyUser(); - - const pathParts = splitKey(relativeFilePath); - - if (fp.includes('..')(pathParts)) naughtyUser(); - - const recordKeyParts = splitKey(recordDir); - - const fullPathParts = [ - ...recordKeyParts, - 'files', - ...fp.filter(p => p !== '.')(pathParts), - ]; - - return joinKey(fullPathParts); -}; - -const downloadFile = app => async (recordKey, relativePath) => apiWrapper( - app, - events.recordApi.uploadFile, - permission.readRecord.isAuthorized(recordKey), - { recordKey, relativePath },//remove dupe key 'recordKey' from object - _downloadFile, app, recordKey, relativePath, -); - - -const _downloadFile = async (app, recordKey, relativePath) => { - if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); } - if (isNothing(relativePath)) { throw new BadRequestError('file path not supplied'); } - - const {dir} = getRecordInfo(app.hierarchy, recordKey); - return await app.datastore.readableFileStream( - safeGetFullFilePath( - dir, relativePath, - ), - ); -}; - -const customId = app => (nodeName, id) => { - const node = $(app.hierarchy, [ - getFlattenedHierarchy, - fp.find(n => n.name === nodeName), - ]); - - if (!node) throw new NotFoundError(`Cannot find node ${nodeName}`); - - return `${node.nodeId}-${id}`; -}; - -const setCustomId = app => (record, id) => { - record.id = customId(app)(record.type, id); - - const keyParts = splitKey(record.key); - - record.key = $(keyParts, [ - fp.take(keyParts.length - 1), - fp.union([record.id]), - joinKey, - ]); - - return record; -}; - -const api = app => ({ - getNew: getNew(app), - getNewChild: getNewChild(app), - save: save(app), - load: load(app), - delete: deleteRecord$1(app, false), - validate: validate(app), - getContext: getContext(app), - uploadFile: uploadFile(app), - downloadFile: downloadFile(app), - customId: customId(app), - setCustomId: setCustomId(app), -}); - - -const getRecordApi = app => api(app); - -const getAllowedRecordTypes = app => key => apiWrapperSync( - app, - events.collectionApi.getAllowedRecordTypes, - alwaysAuthorized, - { key }, - _getAllowedRecordTypes, app, key, -); - -const _getAllowedRecordTypes = (app, key) => { - key = safeKey(key); - const node = getNodeForCollectionPath(app.hierarchy)(key); - return isNothing(node) ? [] : [node.name]; -}; - -const getCollectionApi = app => ({ - getAllowedRecordTypes: getAllowedRecordTypes(app), - getAllIdsIterator: getAllIdsIterator(app), - delete: deleteCollection(app), -}); - -/** rebuilds an index - * @param {object} app - the application container - * @param {string} indexNodeKey - node key of the index, which the index belongs to - */ -const buildIndex = app => async indexNodeKey => apiWrapper( - app, - events.indexApi.buildIndex, - permission.manageIndex.isAuthorized, - { indexNodeKey }, - _buildIndex, app, indexNodeKey, -); - -const _buildIndex = async (app, indexNodeKey) => { - const indexNode = getNode(app.hierarchy, indexNodeKey); - - await createBuildIndexFolder(app.datastore, indexNodeKey); - - if (!isIndex(indexNode)) { throw new BadRequestError('BuildIndex: must supply an indexnode'); } - - if (indexNode.indexType === 'reference') { - await buildReverseReferenceIndex( - app, indexNode, - ); - } else { - await buildHeirarchalIndex( - app, indexNode, - ); - } - - await app.cleanupTransactions(); -}; - -const buildReverseReferenceIndex = async (app, indexNode) => { - // Iterate through all referencING records, - // and update referenced index for each record - let recordCount = 0; - const referencingNodes = $(app.hierarchy, [ - getFlattenedHierarchy, - fp.filter(n => isRecord(n) - && fp.some(fieldReversesReferenceToIndex(indexNode))(n.fields)), - ]); - - const createTransactionsForReferencingNode = async (referencingNode) => { - const iterateReferencingNodes = await getAllIdsIterator(app)(referencingNode.collectionNodeKey()); - - let referencingIdIterator = await iterateReferencingNodes(); - while (!referencingIdIterator.done) { - const { result } = referencingIdIterator; - for (const id of result.ids) { - const recordKey = joinKey(result.collectionKey, id); - await transactionForBuildIndex(app, indexNode.nodeKey(), recordKey, recordCount); - recordCount++; - } - referencingIdIterator = await iterateReferencingNodes(); - } - }; - - for (const referencingNode of referencingNodes) { - await createTransactionsForReferencingNode(referencingNode); - } -}; - -/* -const getAllowedParentCollectionNodes = (hierarchy, indexNode) => $(getAllowedRecordNodesForIndex(hierarchy, indexNode), [ - map(n => n.parent()), -]); -*/ - -const buildHeirarchalIndex = async (app, indexNode) => { - let recordCount = 0; - - const createTransactionsForIds = async (collectionKey, ids) => { - for (const recordId of ids) { - const recordKey = joinKey(collectionKey, recordId); - - const recordNode = getRecordNodeById( - app.hierarchy, - recordId, - ); - - if (recordNodeApplies(indexNode)(recordNode)) { - await transactionForBuildIndex( - app, indexNode.nodeKey(), - recordKey, recordCount, - ); - recordCount++; - } - } - }; - - - const collectionRecords = getAllowedRecordNodesForIndex(app.hierarchy, indexNode); - - for (const targetCollectionRecordNode of collectionRecords) { - const allIdsIterator = await getAllIdsIterator(app)(targetCollectionRecordNode.collectionNodeKey()); - - let allIds = await allIdsIterator(); - while (allIds.done === false) { - await createTransactionsForIds( - allIds.result.collectionKey, - allIds.result.ids, - ); - allIds = await allIdsIterator(); - } - } - - return recordCount; -}; - -// const chooseChildRecordNodeByKey = (collectionNode, recordId) => find(c => recordId.startsWith(c.nodeId))(collectionNode.children); - -const recordNodeApplies = indexNode => recordNode => fp.includes(recordNode.nodeId)(indexNode.allowedRecordNodeIds); - -const aggregates = app => async (indexKey, rangeStartParams = null, rangeEndParams = null) => apiWrapper( - app, - events.indexApi.aggregates, - permission.readIndex.isAuthorized(indexKey), - { indexKey, rangeStartParams, rangeEndParams }, - _aggregates, app, indexKey, rangeStartParams, rangeEndParams, -); - -const _aggregates = async (app, indexKey, rangeStartParams, rangeEndParams) => { - indexKey = safeKey(indexKey); - const indexNode = getExactNodeForKey(app.hierarchy)(indexKey); - const indexDir = getIndexDir(app.hierarchy, indexKey); - - if (!isIndex(indexNode)) { throw new BadRequestError('supplied key is not an index'); } - - if (isShardedIndex(indexNode)) { - const shardKeys = await getShardKeysInRange( - app, indexNode, indexDir, rangeStartParams, rangeEndParams, - ); - let aggregateResult = null; - for (const k of shardKeys) { - const shardResult = await getAggregates(app.hierarchy, app.datastore, indexNode, k); - if (aggregateResult === null) { - aggregateResult = shardResult; - } else { - aggregateResult = mergeShardAggregate( - aggregateResult, - shardResult, - ); - } - } - return aggregateResult; - } - return await getAggregates( - app.hierarchy, - app.datastore, - indexNode, - getUnshardedIndexDataKey(indexDir), - ); -}; - -const mergeShardAggregate = (totals, shard) => { - const mergeGrouping = (tot, shr) => { - tot.count += shr.count; - for (const aggName in tot) { - if (aggName === 'count') continue; - const totagg = tot[aggName]; - const shragg = shr[aggName]; - totagg.sum += shragg.sum; - totagg.max = totagg.max > shragg.max - ? totagg.max - : shragg.max; - totagg.min = totagg.min < shragg.min - ? totagg.min - : shragg.min; - totagg.mean = totagg.sum / tot.count; - } - return tot; - }; - - for (const aggGroupDef in totals) { - for (const grouping in shard[aggGroupDef]) { - const groupingTotal = totals[aggGroupDef][grouping]; - totals[aggGroupDef][grouping] = fp.isUndefined(groupingTotal) - ? shard[aggGroupDef][grouping] - : mergeGrouping( - totals[aggGroupDef][grouping], - shard[aggGroupDef][grouping], - ); - } - } - - return totals; -}; - -const getAggregates = async (hierarchy, datastore, index, indexedDataKey) => { - const aggregateResult = {}; - const doRead = iterateIndex( - async item => { - applyItemToAggregateResult( - index, aggregateResult, item, - ); - return CONTINUE_READING_RECORDS; - }, - async () => aggregateResult - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); -}; - - -const applyItemToAggregateResult = (indexNode, result, item) => { - const getInitialAggregateResult = () => ({ - sum: 0, mean: null, max: null, min: null, - }); - - const applyAggregateResult = (agg, existing, count) => { - const value = compilerUtil.compileCode(agg.aggregatedValue)({ record: item }); - - if (!fp.isNumber(value)) return existing; - - existing.sum += value; - existing.max = value > existing.max || existing.max === null - ? value - : existing.max; - existing.min = value < existing.min || existing.min === null - ? value - : existing.min; - existing.mean = existing.sum / count; - return existing; - }; - - for (const aggGroup of indexNode.aggregateGroups) { - if (!fp.has(aggGroup.name)(result)) { - result[aggGroup.name] = {}; - } - - const thisGroupResult = result[aggGroup.name]; - - if (isNonEmptyString(aggGroup.condition)) { - if (!compilerUtil.compileExpression(aggGroup.condition)({ record: item })) { - continue; - } - } - - let group = isNonEmptyString(aggGroup.groupBy) - ? compilerUtil.compileCode(aggGroup.groupBy)({ record: item }) - : 'all'; - if (!isNonEmptyString(group)) { - group = '(none)'; - } - - if (!fp.has(group)(thisGroupResult)) { - thisGroupResult[group] = { count: 0 }; - for (const agg of aggGroup.aggregates) { - thisGroupResult[group][agg.name] = getInitialAggregateResult(); - } - } - - thisGroupResult[group].count++; - - for (const agg of aggGroup.aggregates) { - const existingValues = thisGroupResult[group][agg.name]; - thisGroupResult[group][agg.name] = applyAggregateResult( - agg, existingValues, - thisGroupResult[group].count, - ); - } - } -}; - -const getIndexApi = app => ({ - listItems: listItems(app), - buildIndex: buildIndex(app), - aggregates: aggregates(app), -}); - -const createNodeErrors = { - indexCannotBeParent: 'Index template cannot be a parent', - allNonRootNodesMustHaveParent: 'Only the root node may have no parent', - indexParentMustBeRecordOrRoot: 'An index may only have a record or root as a parent', - aggregateParentMustBeAnIndex: 'aggregateGroup parent must be an index', -}; - -const pathRegxMaker = node => () => node.nodeKey().replace(/{id}/g, '[a-zA-Z0-9_-]+'); - -const nodeKeyMaker = node => () => switchCase( - - [n => isRecord(n) && !isSingleRecord(n), - n => joinKey( - node.parent().nodeKey(), - node.collectionName, - `${n.nodeId}-{id}`, - )], - - [isRoot, - fp.constant('/')], - - [defaultCase, - n => joinKey(node.parent().nodeKey(), n.name)], - -)(node); - - -const validate$1 = parent => (node) => { - if (isIndex(node) - && isSomething(parent) - && !isRoot(parent) - && !isRecord(parent)) { - throw new BadRequestError(createNodeErrors.indexParentMustBeRecordOrRoot); - } - - if (isaggregateGroup(node) - && isSomething(parent) - && !isIndex(parent)) { - throw new BadRequestError(createNodeErrors.aggregateParentMustBeAnIndex); - } - - if (isNothing(parent) && !isRoot(node)) { throw new BadRequestError(createNodeErrors.allNonRootNodesMustHaveParent); } - - return node; -}; - -const construct = parent => (node) => { - node.nodeKey = nodeKeyMaker(node); - node.pathRegx = pathRegxMaker(node); - node.parent = fp.constant(parent); - node.isRoot = () => isNothing(parent) - && node.name === 'root' - && node.type === 'root'; - if (isCollectionRecord(node)) { - node.collectionNodeKey = () => joinKey( - parent.nodeKey(), node.collectionName, - ); - node.collectionPathRegx = () => joinKey( - parent.pathRegx(), node.collectionName, - ); - } - return node; -}; - -const addToParent = (obj) => { - const parent = obj.parent(); - if (isSomething(parent)) { - if (isIndex(obj)) - // Q: why are indexes not children ? - // A: because they cannot have children of their own. - { - parent.indexes.push(obj); - } - else if (isaggregateGroup(obj)) - { - parent.aggregateGroups.push(obj); - } else { - parent.children.push(obj); - } - - if (isRecord(obj)) { - const defaultIndex = _.find( - parent.indexes, - i => i.name === `${parent.name}_index`, - ); - if (defaultIndex) { - defaultIndex.allowedRecordNodeIds.push(obj.nodeId); - } - } - } - return obj; -}; - -const constructNode = (parent, obj) => $(obj, [ - construct(parent), - validate$1(parent), - addToParent, -]); - -const getNodeId = (parentNode) => { - // this case is handled better elsewhere - if (!parentNode) return null; - const findRoot = n => (isRoot(n) ? n : findRoot(n.parent())); - const root = findRoot(parentNode); - - return ($(root, [ - getFlattenedHierarchy, - fp.map(n => n.nodeId), - fp.max]) + 1); -}; - -const constructHierarchy = (node, parent) => { - construct(parent)(node); - if (node.indexes) { - _.each(node.indexes, - child => constructHierarchy(child, node)); - } - if (node.aggregateGroups) { - _.each(node.aggregateGroups, - child => constructHierarchy(child, node)); - } - if (node.children && node.children.length > 0) { - _.each(node.children, - child => constructHierarchy(child, node)); - } - if (node.fields) { - _.each(node.fields, - f => _.each(f.typeOptions, (val, key) => { - const def = all$1[f.type].optionDefinitions[key]; - if (!def) { - // unknown typeOption - delete f.typeOptions[key]; - } else { - f.typeOptions[key] = def.parse(val); - } - })); - } - return node; -}; - - -const getNewRootLevel = () => construct()({ - name: 'root', - type: 'root', - children: [], - pathMaps: [], - indexes: [], - nodeId: 0, -}); - -const _getNewRecordTemplate = (parent, name, createDefaultIndex, isSingle) => { - const node = constructNode(parent, { - name, - type: 'record', - fields: [], - children: [], - validationRules: [], - nodeId: getNodeId(parent), - indexes: [], - estimatedRecordCount: isRecord(parent) ? 500 : 1000000, - collectionName: '', - isSingle, - }); - - if (createDefaultIndex) { - const defaultIndex = getNewIndexTemplate(parent); - defaultIndex.name = `${name}_index`; - defaultIndex.allowedRecordNodeIds.push(node.nodeId); - } - - return node; -}; - -const getNewRecordTemplate = (parent, name = '', createDefaultIndex = true) => _getNewRecordTemplate(parent, name, createDefaultIndex, false); - -const getNewSingleRecordTemplate = parent => _getNewRecordTemplate(parent, '', false, true); - -const getNewIndexTemplate = (parent, type = 'ancestor') => constructNode(parent, { - name: '', - type: 'index', - map: 'return {...record};', - filter: '', - indexType: type, - getShardName: '', - getSortKey: 'record.id', - aggregateGroups: [], - allowedRecordNodeIds: [], - nodeId: getNodeId(parent), -}); - -const getNewAggregateGroupTemplate = index => constructNode(index, { - name: '', - type: 'aggregateGroup', - groupBy: '', - aggregates: [], - condition: '', - nodeId: getNodeId(index), -}); - -const getNewAggregateTemplate = (set) => { - const aggregatedValue = { - name: '', - aggregatedValue: '', - }; - set.aggregates.push(aggregatedValue); - return aggregatedValue; -}; - -const fieldErrors = { - AddFieldValidationFailed: 'Add field validation: ', -}; - -const allowedTypes = () => fp.keys(all$1); - -const getNewField = type => ({ - name: '', // how field is referenced internally - type, - typeOptions: getDefaultOptions$1(type), - label: '', // how field is displayed - getInitialValue: 'default', // function that gets value when initially created - getUndefinedValue: 'default', // function that gets value when field undefined on record -}); - -const fieldRules = allFields => [ - makerule('name', 'field name is not set', - f => isNonEmptyString(f.name)), - makerule('type', 'field type is not set', - f => isNonEmptyString(f.type)), - makerule('label', 'field label is not set', - f => isNonEmptyString(f.label)), - makerule('getInitialValue', 'getInitialValue function is not set', - f => isNonEmptyString(f.getInitialValue)), - makerule('getUndefinedValue', 'getUndefinedValue function is not set', - f => isNonEmptyString(f.getUndefinedValue)), - makerule('name', 'field name is duplicated', - f => isNothingOrEmpty(f.name) - || fp.countBy('name')(allFields)[f.name] === 1), - makerule('type', 'type is unknown', - f => isNothingOrEmpty(f.type) - || fp.some(t => f.type === t)(allowedTypes())), -]; - -const typeOptionsRules = (field) => { - const type = all$1[field.type]; - if (isNothing(type)) return []; - - const def = optName => type.optionDefinitions[optName]; - - return $(field.typeOptions, [ - fp.keys, - fp.filter(o => isSomething(def(o)) - && isSomething(def(o).isValid)), - fp.map(o => makerule( - `typeOptions.${o}`, - `${def(o).requirementDescription}`, - field => def(o).isValid(field.typeOptions[o]), - )), - ]); -}; - -const validateField = allFields => (field) => { - const everySingleField = fp.includes(field)(allFields) ? allFields : [...allFields, field]; - return applyRuleSet([...fieldRules(everySingleField), ...typeOptionsRules(field)])(field); -}; - -const validateAllFields = recordNode => $(recordNode.fields, [ - fp.map(validateField(recordNode.fields)), - fp.flatten, -]); - -const addField = (recordTemplate, field) => { - if (isNothingOrEmpty(field.label)) { - field.label = field.name; - } - const validationMessages = validateField([...recordTemplate.fields, field])(field); - if (validationMessages.length > 0) { - const errors = fp.map(m => m.error)(validationMessages); - throw new BadRequestError(`${fieldErrors.AddFieldValidationFailed} ${errors.join(', ')}`); - } - recordTemplate.fields.push(field); -}; - -const getNewRecordValidationRule = (invalidFields, - messageWhenInvalid, - expressionWhenValid) => ({ - invalidFields, messageWhenInvalid, expressionWhenValid, -}); - -const getStaticValue = switchCase( - [fp.isNumber, v => v.toString()], - [fp.isBoolean, v => v.toString()], - [fp.defaultCase, v => `'${v}'`], -); - -const commonRecordValidationRules = ({ - - fieldNotEmpty: fieldName => getNewRecordValidationRule( - [fieldName], - `${fieldName} is empty`, - `!_.isEmpty(record['${fieldName}'])`, - ), - - fieldBetween: (fieldName, min, max) => getNewRecordValidationRule( - [fieldName], - `${fieldName} must be between ${min.toString()} and ${max.toString()}`, - `record['${fieldName}'] >= ${getStaticValue(min)} && record['${fieldName}'] <= ${getStaticValue(max)} `, - ), - - fieldGreaterThan: (fieldName, min, max) => getNewRecordValidationRule( - [fieldName], - `${fieldName} must be greater than ${min.toString()} and ${max.toString()}`, - `record['${fieldName}'] >= ${getStaticValue(min)} `, - ), -}); - -const addRecordValidationRule = recordNode => rule => recordNode.validationRules.push(rule); - -const createTrigger = () => ({ - actionName: '', - eventName: '', - // function, has access to event context, - // returns object that is used as parameter to action - // only used if triggered by event - optionsCreator: '', - // action runs if true, - // has access to event context - condition: '', -}); - -const createAction = () => ({ - name: '', - behaviourSource: '', - // name of function in actionSource - behaviourName: '', - // parameter passed into behaviour. - // any other parms passed at runtime e.g. - // by trigger, or manually, will be merged into this - initialOptions: {}, -}); - -const aggregateRules = [ - makerule('name', 'choose a name for the aggregate', - a => isNonEmptyString(a.name)), - makerule('aggregatedValue', 'aggregatedValue does not compile', - a => fp.isEmpty(a.aggregatedValue) - || executesWithoutException( - () => compilerUtil.compileCode(a.aggregatedValue), - )), -]; - -const validateAggregate = aggregate => applyRuleSet(aggregateRules)(aggregate); - -const validateAllAggregates = all => $(all, [ - fp.map(validateAggregate), - fp.flatten, -]); - -const ruleSet = (...sets) => fp.constant(fp.flatten([...sets])); - -const commonRules = [ - makerule('name', 'node name is not set', - node => stringNotEmpty(node.name)), - makerule('type', 'node type not recognised', - anyTrue(isRecord, isRoot, isIndex, isaggregateGroup)), -]; - -const recordRules = [ - makerule('fields', 'no fields have been added to the record', - node => isNonEmptyArray(node.fields)), - makerule('validationRules', "validation rule is missing a 'messageWhenValid' member", - node => fp.every(r => fp.has('messageWhenInvalid')(r))(node.validationRules)), - makerule('validationRules', "validation rule is missing a 'expressionWhenValid' member", - node => fp.every(r => fp.has('expressionWhenValid')(r))(node.validationRules)), -]; - - -const aggregateGroupRules = [ - makerule('condition', 'condition does not compile', - a => fp.isEmpty(a.condition) - || executesWithoutException( - () => compilerUtil.compileExpression(a.condition), - )), -]; - -const getRuleSet = node => switchCase( - - [isRecord, ruleSet( - commonRules, - recordRules, - )], - - [isIndex, ruleSet( - commonRules, - indexRuleSet, - )], - - [isaggregateGroup, ruleSet( - commonRules, - aggregateGroupRules, - )], - - [defaultCase, ruleSet(commonRules, [])], -)(node); - -const validateNode = node => applyRuleSet(getRuleSet(node))(node); - -const validateAll = (appHierarchy) => { - const flattened = getFlattenedHierarchy( - appHierarchy, - ); - - const duplicateNameRule = makerule( - 'name', 'node names must be unique under shared parent', - n => fp.filter(f => f.parent() === n.parent() - && f.name === n.name)(flattened).length === 1, - ); - - const duplicateNodeKeyErrors = $(flattened, [ - fp.map(n => applyRuleSet([duplicateNameRule])(n)), - fp.filter(isSomething), - fp.flatten, - ]); - - const fieldErrors = $(flattened, [ - fp.filter(isRecord), - fp.map(validateAllFields), - fp.flatten, - ]); - - const aggregateErrors = $(flattened, [ - fp.filter(isaggregateGroup), - fp.map(s => validateAllAggregates( - s.aggregates, - )), - fp.flatten, - ]); - - return $(flattened, [ - fp.map(validateNode), - fp.flatten, - fp.union(duplicateNodeKeyErrors), - fp.union(fieldErrors), - fp.union(aggregateErrors), - ]); -}; - -const actionRules = [ - makerule('name', 'action must have a name', - a => isNonEmptyString(a.name)), - makerule('behaviourName', 'must supply a behaviour name to the action', - a => isNonEmptyString(a.behaviourName)), - makerule('behaviourSource', 'must supply a behaviour source for the action', - a => isNonEmptyString(a.behaviourSource)), -]; - -const duplicateActionRule = makerule('', 'action name must be unique', () => {}); - -const validateAction = action => applyRuleSet(actionRules)(action); - - -const validateActions = (allActions) => { - const duplicateActions = $(allActions, [ - fp.filter(a => fp.filter(a2 => a2.name === a.name)(allActions).length > 1), - fp.map(a => validationError(duplicateActionRule, a)), - ]); - - const errors = $(allActions, [ - fp.map(validateAction), - fp.flatten, - fp.union(duplicateActions), - fp.uniqBy('name'), - ]); - - return errors; -}; - -const triggerRules = actions => ([ - makerule('actionName', 'must specify an action', - t => isNonEmptyString(t.actionName)), - makerule('eventName', 'must specify and event', - t => isNonEmptyString(t.eventName)), - makerule('actionName', 'specified action not supplied', - t => !t.actionName - || fp.some(a => a.name === t.actionName)(actions)), - makerule('eventName', 'invalid Event Name', - t => !t.eventName - || fp.includes(t.eventName)(eventsList)), - makerule('optionsCreator', 'Options Creator does not compile - check your expression', - (t) => { - if (!t.optionsCreator) return true; - try { - compilerUtil.compileCode(t.optionsCreator); - return true; - } catch (_) { return false; } - }), - makerule('condition', 'Trigger condition does not compile - check your expression', - (t) => { - if (!t.condition) return true; - try { - compilerUtil.compileExpression(t.condition); - return true; - } catch (_) { return false; } - }), -]); - -const validateTrigger = (trigger, allActions) => { - const errors = applyRuleSet(triggerRules(allActions))(trigger); - - return errors; -}; - -const validateTriggers = (triggers, allActions) => $(triggers, [ - fp.map(t => validateTrigger(t, allActions)), - fp.flatten, -]); - -const getApplicationDefinition = datastore => async () => { - const exists = await datastore.exists(appDefinitionFile); - - if (!exists) throw new Error('Application definition does not exist'); - - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.hierarchy = constructHierarchy( - appDefinition.hierarchy, - ); - return appDefinition; -}; - -const saveApplicationHierarchy = app => async hierarchy => apiWrapper( - app, - events.templateApi.saveApplicationHierarchy, - permission.writeTemplates.isAuthorized, - { hierarchy }, - _saveApplicationHierarchy, app.datastore, hierarchy, -); - - -const _saveApplicationHierarchy = async (datastore, hierarchy) => { - const validationErrors = await validateAll(hierarchy); - if (validationErrors.length > 0) { - throw new Error(`Hierarchy is invalid: ${_.join( - validationErrors.map(e => `${e.item.nodeKey ? e.item.nodeKey() : ''} : ${e.error}`), - ',', - )}`); - } - - if (await datastore.exists(appDefinitionFile)) { - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.hierarchy = hierarchy; - await datastore.updateJson(appDefinitionFile, appDefinition); - } else { - await datastore.createFolder('/.config'); - const appDefinition = { actions: [], triggers: [], hierarchy }; - await datastore.createJson(appDefinitionFile, appDefinition); - } -}; - -const saveActionsAndTriggers = app => async (actions, triggers) => apiWrapper( - app, - events.templateApi.saveActionsAndTriggers, - permission.writeTemplates.isAuthorized, - { actions, triggers }, - _saveActionsAndTriggers, app.datastore, actions, triggers, -); - -const _saveActionsAndTriggers = async (datastore, actions, triggers) => { - if (await datastore.exists(appDefinitionFile)) { - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.actions = actions; - appDefinition.triggers = triggers; - - const actionValidErrs = fp.map(e => e.error)(validateActions(actions)); - - if (actionValidErrs.length > 0) { - throw new BadRequestError(`Actions are invalid: ${_.join(actionValidErrs, ', ')}`); - } - - const triggerValidErrs = fp.map(e => e.error)(validateTriggers(triggers, actions)); - - if (triggerValidErrs.length > 0) { - throw new BadRequestError(`Triggers are invalid: ${_.join(triggerValidErrs, ', ')}`); - } - - await datastore.updateJson(appDefinitionFile, appDefinition); - } else { - throw new BadRequestError('Cannot save actions: Application definition does not exist'); - } -}; - -const getBehaviourSources = async (datastore) => { - await datastore.loadFile('/.config/behaviourSources.js'); -}; - -const api$1 = app => ({ - - getApplicationDefinition: getApplicationDefinition(app.datastore), - saveApplicationHierarchy: saveApplicationHierarchy(app), - saveActionsAndTriggers: saveActionsAndTriggers(app), - getBehaviourSources: () => getBehaviourSources(app.datastore), - getNewRootLevel, - constructNode, - getNewIndexTemplate, - getNewRecordTemplate, - getNewField, - validateField, - addField, - fieldErrors, - getNewRecordValidationRule, - commonRecordValidationRules, - addRecordValidationRule, - createAction, - createTrigger, - validateActions, - validateTrigger, - getNewAggregateGroupTemplate, - getNewAggregateTemplate, - constructHierarchy, - getNewSingleRecordTemplate, - allTypes: all$1, - validateNode, - validateAll, - validateTriggers, -}); - - -const getTemplateApi = app => api$1(app); - -const getUsers = app => async () => apiWrapper( - app, - events.authApi.getUsers, - permission.listUsers.isAuthorized, - {}, - _getUsers, app, -); - -const _getUsers = async app => $(await app.datastore.loadJson(USERS_LIST_FILE), [ - fp.map(stripUserOfSensitiveStuff), -]); - -const loadAccessLevels = app => async () => apiWrapper( - app, - events.authApi.loadAccessLevels, - permission.listAccessLevels.isAuthorized, - {}, - _loadAccessLevels, app, -); - -const _loadAccessLevels = async app => await app.datastore.loadJson(ACCESS_LEVELS_FILE); - -const dummyHash = '$argon2i$v=19$m=4096,t=3,p=1$UZRo409UYBGjHJS3CV6Uxw$rU84qUqPeORFzKYmYY0ceBLDaPO+JWSH4PfNiKXfIKk'; - -const authenticate = app => async (username, password) => apiWrapper( - app, - events.authApi.authenticate, - alwaysAuthorized, - { username, password }, - _authenticate, app, username, password, -); - -const _authenticate = async (app, username, password) => { - if (isNothingOrEmpty(username) || isNothingOrEmpty(password)) { return null; } - - const allUsers = await _getUsers(app); - let user = getUserByName( - allUsers, - username, - ); - - const notAUser = 'not-a-user'; - // continue with non-user - so time to verify remains consistent - // with verification of a valid user - if (!user || !user.enabled) { user = notAUser; } - - let userAuth; - try { - userAuth = await app.datastore.loadJson( - userAuthFile(username), - ); - } catch (_) { - userAuth = { accessLevels: [], passwordHash: dummyHash }; - } - - const permissions = await buildUserPermissions(app, user.accessLevels); - - const verified = await app.crypto.verify( - userAuth.passwordHash, - password, - ); - - if (user === notAUser) { return null; } - - return verified - ? { - ...user, permissions, temp: false, isUser: true, - } - : null; -}; - -const authenticateTemporaryAccess = app => async (tempAccessCode) => { - if (isNothingOrEmpty(tempAccessCode)) { return null; } - - const temp = parseTemporaryCode(tempAccessCode); - let user = $(await _getUsers(app), [ - fp.find(u => u.temporaryAccessId === temp.id), - ]); - - const notAUser = 'not-a-user'; - if (!user || !user.enabled) { user = notAUser; } - - let userAuth; - try { - userAuth = await app.datastore.loadJson( - userAuthFile(user.name), - ); - } catch (e) { - userAuth = { - temporaryAccessHash: dummyHash, - temporaryAccessExpiryEpoch: (await app.getEpochTime() + 10000), - }; - } - - if (userAuth.temporaryAccessExpiryEpoch < await app.getEpochTime()) { user = notAUser; } - - const tempCode = !temp.code ? shortid.generate() : temp.code; - const verified = await app.crypto.verify( - userAuth.temporaryAccessHash, - tempCode, - ); - - if (user === notAUser) { return null; } - - return verified - ? { - ...user, - permissions: [], - temp: true, - isUser: true, - } - : null; -}; - -const buildUserPermissions = async (app, userAccessLevels) => { - const allAccessLevels = await _loadAccessLevels(app); - - return $(allAccessLevels.levels, [ - fp.filter(l => fp.some(ua => l.name === ua)(userAccessLevels)), - fp.map(l => l.permissions), - fp.flatten, - ]); -}; - -const createTemporaryAccess$1 = app => async userName => apiWrapper( - app, - events.authApi.createTemporaryAccess, - alwaysAuthorized, - { userName }, - _createTemporaryAccess, app, userName, -); - -const _createTemporaryAccess = async (app, userName) => { - const tempCode = await getTemporaryCode(app); - - const lock = await getLock( - app, USERS_LOCK_FILE, 1000, 2, - ); - - if (isNolock(lock)) { throw new Error('Unable to create temporary access, could not get lock - try again'); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - - const user = getUserByName(users, userName); - user.temporaryAccessId = tempCode.temporaryAccessId; - - await app.datastore.updateJson( - USERS_LIST_FILE, - users, - ); - } finally { - await releaseLock(app, lock); - } - - const userAuth = await app.datastore.loadJson( - userAuthFile(userName), - ); - userAuth.temporaryAccessHash = tempCode.temporaryAccessHash; - - userAuth.temporaryAccessExpiryEpoch = tempCode.temporaryAccessExpiryEpoch; - - await app.datastore.updateJson( - userAuthFile(userName), - userAuth, - ); - - return tempCode.tempCode; -}; - -const getTemporaryCode = async (app) => { - const tempCode = shortid.generate() - + shortid.generate() - + shortid.generate() - + shortid.generate(); - - const tempId = shortid.generate(); - - return { - temporaryAccessHash: await app.crypto.hash( - tempCode, - ), - temporaryAccessExpiryEpoch: - (await app.getEpochTime()) + tempCodeExpiryLength, - tempCode: `tmp:${tempId}:${tempCode}`, - temporaryAccessId: tempId, - }; -}; - -const userRules = allUsers => [ - makerule('name', 'username must be set', - u => isNonEmptyString(u.name)), - makerule('accessLevels', 'user must have at least one access level', - u => u.accessLevels.length > 0), - makerule('name', 'username must be unique', - u => fp.filter(u2 => insensitiveEquals(u2.name, u.name))(allUsers).length === 1), - makerule('accessLevels', 'access levels must only contain stings', - u => all(isNonEmptyString)(u.accessLevels)), -]; - -const validateUser = () => (allusers, user) => applyRuleSet(userRules(allusers))(user); - -const getNewUser = app => () => apiWrapperSync( - app, - events.authApi.getNewUser, - permission.createUser.isAuthorized, - {}, - _getNewUser, app, -); - -const _getNewUser = () => ({ - name: '', - accessLevels: [], - enabled: true, - temporaryAccessId: '', -}); - -const getNewUserAuth = app => () => apiWrapperSync( - app, - events.authApi.getNewUserAuth, - permission.createUser.isAuthorized, - {}, - _getNewUserAuth, app, -); - -const _getNewUserAuth = () => ({ - passwordHash: '', - temporaryAccessHash: '', - temporaryAccessExpiryEpoch: 0, -}); - -const isValidPassword = app => password => apiWrapperSync( - app, - events.authApi.isValidPassword, - alwaysAuthorized, - { password }, - _isValidPassword, app, password, -); - -const _isValidPassword = (app, password) => scorePassword(password).score > 30; - -const changeMyPassword = app => async (currentPw, newpassword) => apiWrapper( - app, - events.authApi.changeMyPassword, - alwaysAuthorized, - { currentPw, newpassword }, - _changeMyPassword, app, currentPw, newpassword, -); - -const _changeMyPassword = async (app, currentPw, newpassword) => { - const existingAuth = await app.datastore.loadJson( - userAuthFile(app.user.name), - ); - - if (isSomething(existingAuth.passwordHash)) { - const verified = await app.crypto.verify( - existingAuth.passwordHash, - currentPw, - ); - - if (verified) { - await await doSet( - app, existingAuth, - app.user.name, newpassword, - ); - return true; - } - } - - return false; -}; - -const setPasswordFromTemporaryCode = app => async (tempCode, newpassword) => apiWrapper( - app, - events.authApi.setPasswordFromTemporaryCode, - alwaysAuthorized, - { tempCode, newpassword }, - _setPasswordFromTemporaryCode, app, tempCode, newpassword, -); - - -const _setPasswordFromTemporaryCode = async (app, tempCode, newpassword) => { - const currentTime = await app.getEpochTime(); - - const temp = parseTemporaryCode(tempCode); - - const user = $(await _getUsers(app), [ - fp.find(u => u.temporaryAccessId === temp.id), - ]); - - if (!user) { return false; } - - const existingAuth = await app.datastore.loadJson( - userAuthFile(user.name), - ); - - if (isSomething(existingAuth.temporaryAccessHash) - && existingAuth.temporaryAccessExpiryEpoch > currentTime) { - const verified = await app.crypto.verify( - existingAuth.temporaryAccessHash, - temp.code, - ); - - if (verified) { - await doSet( - app, existingAuth, - user.name, newpassword, - ); - return true; - } - } - - return false; -}; - -const doSet = async (app, auth, username, newpassword) => { - auth.temporaryAccessHash = ''; - auth.temporaryAccessExpiryEpoch = 0; - auth.passwordHash = await app.crypto.hash( - newpassword, - ); - await app.datastore.updateJson( - userAuthFile(username), - auth, - ); -}; - -const scorePassword = app => password => apiWrapperSync( - app, - events.authApi.scorePassword, - alwaysAuthorized, - { password }, - _scorePassword, password, -); - -const _scorePassword = (password) => { - // from https://stackoverflow.com/questions/948172/password-strength-meter - // thank you https://stackoverflow.com/users/46617/tm-lv - - let score = 0; - if (!password) { return score; } - - // award every unique letter until 5 repetitions - const letters = new Object(); - for (let i = 0; i < password.length; i++) { - letters[password[i]] = (letters[password[i]] || 0) + 1; - score += 5.0 / letters[password[i]]; - } - - // bonus points for mixing it up - const variations = { - digits: /\d/.test(password), - lower: /[a-z]/.test(password), - upper: /[A-Z]/.test(password), - nonWords: /\W/.test(password), - }; - - let variationCount = 0; - for (const check in variations) { - variationCount += (variations[check] == true) ? 1 : 0; - } - score += (variationCount - 1) * 10; - - const strengthText = score > 80 - ? 'strong' - : score > 60 - ? 'good' - : score >= 30 - ? 'weak' - : 'very weak'; - - return { - score: parseInt(score), - strengthText, - }; -}; - -const createUser$1 = app => async (user, password = null) => apiWrapper( - app, - events.authApi.createUser, - permission.createUser.isAuthorized, - { user, password }, - _createUser, app, user, password, -); - -const _createUser = async (app, user, password = null) => { - const lock = await getLock( - app, USERS_LOCK_FILE, 1000, 2, - ); - - if (isNolock(lock)) { throw new Error('Unable to create user, could not get lock - try again'); } - - const users = await app.datastore.loadJson(USERS_LIST_FILE); - - const userErrors = validateUser()([...users, user], user); - if (userErrors.length > 0) { throw new BadRequestError(`User is invalid. ${fp.join('; ')(userErrors)}`); } - - const { auth, tempCode, temporaryAccessId } = await getAccess( - app, password, - ); - user.tempCode = tempCode; - user.temporaryAccessId = temporaryAccessId; - - if (fp.some(u => insensitiveEquals(u.name, user.name))(users)) { - throw new BadRequestError('User already exists'); - } - - users.push( - stripUserOfSensitiveStuff(user), - ); - - await app.datastore.updateJson( - USERS_LIST_FILE, - users, - ); - - try { - await app.datastore.createJson( - userAuthFile(user.name), - auth, - ); - } catch (_) { - await app.datastore.updateJson( - userAuthFile(user.name), - auth, - ); - } - - await releaseLock(app, lock); - - return user; -}; - -const getAccess = async (app, password) => { - const auth = getNewUserAuth(app)(); - - if (isNonEmptyString(password)) { - if (isValidPassword(password)) { - auth.passwordHash = await app.crypto.hash(password); - auth.temporaryAccessHash = ''; - auth.temporaryAccessId = ''; - auth.temporaryAccessExpiryEpoch = 0; - return { auth }; - } - throw new BadRequestError('Password does not meet requirements'); - } else { - const tempAccess = await getTemporaryCode(app); - auth.temporaryAccessHash = tempAccess.temporaryAccessHash; - auth.temporaryAccessExpiryEpoch = tempAccess.temporaryAccessExpiryEpoch; - auth.passwordHash = ''; - return ({ - auth, - tempCode: tempAccess.tempCode, - temporaryAccessId: tempAccess.temporaryAccessId, - }); - } -}; - -const enableUser = app => async username => apiWrapper( - app, - events.authApi.enableUser, - permission.enableDisableUser.isAuthorized, - { username }, - _enableUser, app, username, -); - -const disableUser = app => async username => apiWrapper( - app, - events.authApi.disableUser, - permission.enableDisableUser.isAuthorized, - { username }, - _disableUser, app, username, -); - -const _enableUser = async (app, username) => await toggleUser(app, username, true); - -const _disableUser = async (app, username) => await toggleUser(app, username, false); - -const toggleUser = async (app, username, enabled) => { - const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0); - - const actionName = enabled ? 'enable' : 'disable'; - - if (isNolock(lock)) { throw new Error(`Could not ${actionName} user - cannot get lock`); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - const user = getUserByName(users, username); - if (!user) { throw new NotFoundError(`Could not find user to ${actionName}`); } - - if (user.enabled === !enabled) { - user.enabled = enabled; - await app.datastore.updateJson(USERS_LIST_FILE, users); - } - } finally { - releaseLock(app, lock); - } -}; - -const getNewAccessLevel = () => () => ({ - name: '', - permissions: [], - default:false -}); - -const isAllowedType = t => $(permissionTypes, [ - fp.values, - fp.includes(t), -]); - -const isRecordOrIndexType = t => fp.some(p => p === t)([ - permissionTypes.CREATE_RECORD, - permissionTypes.UPDATE_RECORD, - permissionTypes.DELETE_RECORD, - permissionTypes.READ_RECORD, - permissionTypes.READ_INDEX, - permissionTypes.EXECUTE_ACTION, -]); - - -const permissionRules = app => ([ - makerule('type', 'type must be one of allowed types', - p => isAllowedType(p.type)), - makerule('nodeKey', 'record and index permissions must include a valid nodeKey', - p => (!isRecordOrIndexType(p.type)) - || isSomething(getNode(app.hierarchy, p.nodeKey))), -]); - -const applyPermissionRules = app => applyRuleSet(permissionRules(app)); - -const accessLevelRules = allLevels => ([ - makerule('name', 'name must be set', - l => isNonEmptyString(l.name)), - makerule('name', 'access level names must be unique', - l => fp.isEmpty(l.name) - || fp.filter(a => insensitiveEquals(l.name, a.name))(allLevels).length === 1), -]); - -const applyLevelRules = allLevels => applyRuleSet(accessLevelRules(allLevels)); - -const validateAccessLevel = app => (allLevels, level) => { - const errs = $(level.permissions, [ - fp.map(applyPermissionRules(app)), - fp.flatten, - fp.concat( - applyLevelRules(allLevels)(level), - ), - ]); - - return errs; -}; - -const validateAccessLevels = app => allLevels => apiWrapperSync( - app, - events.authApi.validateAccessLevels, - alwaysAuthorized, - { allLevels }, - _validateAccessLevels, app, allLevels, -); - -const _validateAccessLevels = (app, allLevels) => $(allLevels, [ - fp.map(l => validateAccessLevel(app)(allLevels, l)), - fp.flatten, - fp.uniqWith((x, y) => x.field === y.field - && x.item === y.item - && x.error === y.error), -]); - -const saveAccessLevels = app => async accessLevels => apiWrapper( - app, - events.authApi.saveAccessLevels, - permission.writeAccessLevels.isAuthorized, - { accessLevels }, - _saveAccessLevels, app, accessLevels, -); - -const _saveAccessLevels = async (app, accessLevels) => { - const validationErrors = validateAccessLevels(app)(accessLevels.levels); - if (validationErrors.length > 0) { - const errs = $(validationErrors, [ - fp.map(e => e.error), - fp.join(', '), - ]); - throw new Error( - `Access Levels Invalid: ${errs}`, - ); - } - - const lock = await getLock( - app, ACCESS_LEVELS_LOCK_FILE, 2000, 2, - ); - - if (isNolock(lock)) { throw new Error('Could not get lock to save access levels'); } - - try { - const existing = await app.datastore.loadJson(ACCESS_LEVELS_FILE); - if (existing.version !== accessLevels.version) { throw new Error('Access levels have already been updated, since you loaded'); } - - accessLevels.version++; - - app.datastore.updateJson(ACCESS_LEVELS_FILE, accessLevels); - } finally { - await releaseLock(app, lock); - } -}; - -const generateFullPermissions = (app) => { - const allNodes = getFlattenedHierarchy(app.hierarchy); - const accessLevel = { permissions: [] }; - - const recordNodes = $(allNodes, [ - fp.filter(isRecord), - ]); - - for (const n of recordNodes) { - permission.createRecord.add(n.nodeKey(), accessLevel); - permission.updateRecord.add(n.nodeKey(), accessLevel); - permission.deleteRecord.add(n.nodeKey(), accessLevel); - permission.readRecord.add(n.nodeKey(), accessLevel); - } - - const indexNodes = $(allNodes, [ - fp.filter(isIndex), - ]); - - for (const n of indexNodes) { - permission.readIndex.add(n.nodeKey(), accessLevel); - } - - for (const a of fp.keys(app.actions)) { - permission.executeAction.add(a, accessLevel); - } - - $(permission, [ - fp.values, - fp.filter(p => !p.isNode), - fp.each(p => p.add(accessLevel)), - ]); - - return accessLevel.permissions; -}; - -const setUserAccessLevels$1 = app => async (userName, accessLevels) => apiWrapper( - app, - events.authApi.setUserAccessLevels, - permission.setUserAccessLevels.isAuthorized, - { userName, accessLevels }, - _setUserAccessLevels, app, userName, accessLevels, -); - -const _setUserAccessLevels = async (app, username, accessLevels) => { - const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0); - - const actualAccessLevels = $( - await app.datastore.loadJson(ACCESS_LEVELS_FILE), - [ - l => l.levels, - fp.map(l => l.name), - ], - ); - - const missing = fp.difference(accessLevels)(actualAccessLevels); - if (missing.length > 0) { - throw new Error(`Invalid access levels supplied: ${fp.join(', ', missing)}`); - } - - if (isNolock(lock)) { throw new Error('Could set user access levels cannot get lock'); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - const user = getUserByName(users, username); - if (!user) { throw new NotFoundError(`Could not find user with ${username}`); } - - user.accessLevels = accessLevels; - await app.datastore.updateJson(USERS_LIST_FILE, users); - } finally { - releaseLock(app, lock); - } -}; - -const getAuthApi = app => ({ - authenticate: authenticate(app), - authenticateTemporaryAccess: authenticateTemporaryAccess(app), - createTemporaryAccess: createTemporaryAccess$1(app), - createUser: createUser$1(app), - loadAccessLevels: loadAccessLevels(app), - enableUser: enableUser(app), - disableUser: disableUser(app), - getNewAccessLevel: getNewAccessLevel(), - getNewUser: getNewUser(app), - getNewUserAuth: getNewUserAuth(app), - getUsers: getUsers(app), - saveAccessLevels: saveAccessLevels(app), - isAuthorized: isAuthorized(app), - changeMyPassword: changeMyPassword(app), - setPasswordFromTemporaryCode: setPasswordFromTemporaryCode(app), - scorePassword, - isValidPassword: isValidPassword(app), - validateUser: validateUser(), - validateAccessLevels: validateAccessLevels(app), - generateFullPermissions: () => generateFullPermissions(app), - setUserAccessLevels: setUserAccessLevels$1(app), -}); - -const executeAction$1 = app => (actionName, options) => { - apiWrapperSync( - app, - events.actionsApi.execute, - permission.executeAction.isAuthorized(actionName), - { actionName, options }, - app.actions[actionName], options, - ); -}; - -const _executeAction = (behaviourSources, action, options) => behaviourSources[action.behaviourSource][action.behaviourName](options); - -const getActionsApi = app => ({ - execute: executeAction$1(app), -}); - -const publish = handlers => async (eventName, context = {}) => { - if (!fp.has(eventName)(handlers)) return; - - for (const handler of handlers[eventName]) { - await handler(eventName, context); - } -}; - -const subscribe = handlers => (eventName, handler) => { - if (!fp.has(eventName)(handlers)) { - handlers[eventName] = []; - } - handlers[eventName].push(handler); -}; - -const createEventAggregator = () => { - const handlers = {}; - const eventAggregator = ({ - publish: publish(handlers), - subscribe: subscribe(handlers), - }); - return eventAggregator; -}; - -const createJson = originalCreateFile => async (key, obj, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, key, JSON.stringify(obj)); - -const createNewFile = originalCreateFile => async (path, content, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, path, content); - -const loadJson = datastore => async (key, retries = 3, delay = 100) => { - try { - return await retry(JSON.parse, retries, delay, await datastore.loadFile(key)); - } catch (err) { - const newErr = new NotFoundError(err.message); - newErr.stack = err.stack; - throw(newErr); - } -}; - -const updateJson = datastore => async (key, obj, retries = 3, delay = 100) => { - try { - return await retry(datastore.updateFile, retries, delay, key, JSON.stringify(obj)); - } catch (err) { - const newErr = new NotFoundError(err.message); - newErr.stack = err.stack; - throw(newErr); - } -}; - -const setupDatastore = (datastore) => { - const originalCreateFile = datastore.createFile; - datastore.loadJson = loadJson(datastore); - datastore.createJson = createJson(originalCreateFile); - datastore.updateJson = updateJson(datastore); - datastore.createFile = createNewFile(originalCreateFile); - if (datastore.createEmptyDb) { delete datastore.createEmptyDb; } - return datastore; -}; - -const compileCode = code => { - let func; - - try { - func = compilerUtil.compileCode(code); - } catch(e) { - e.message = `Error compiling code : ${code} : ${e.message}`; - throw e; - } - - return func; -}; - -const compileExpression = code => { - let func; - - try { - func = compilerUtil.compileExpression(code); - } catch(e) { - e.message = `Error compiling expression : ${code} : ${e.message}`; - throw e; - } - - return func; -}; - -const initialiseActions = (subscribe, behaviourSources, actions, triggers, apis) => { - validateSources(behaviourSources, actions); - subscribeTriggers(subscribe, behaviourSources, actions, triggers, apis); - return createActionsCollection(behaviourSources, actions); -}; - -const createActionsCollection = (behaviourSources, actions) => $(actions, [ - fp.reduce((all, a) => { - all[a.name] = opts => _executeAction(behaviourSources, a, opts); - return all; - }, {}), -]); - -const subscribeTriggers = (subscribe, behaviourSources, actions, triggers, apis) => { - const createOptions = (optionsCreator, eventContext) => { - if (!optionsCreator) return {}; - const create = compileCode(optionsCreator); - return create({ context: eventContext, apis }); - }; - - const shouldRunTrigger = (trigger, eventContext) => { - if (!trigger.condition) return true; - const shouldRun = compileExpression(trigger.condition); - return shouldRun({ context: eventContext }); - }; - - for (let trig of triggers) { - subscribe(trig.eventName, async (ev, ctx) => { - if (shouldRunTrigger(trig, ctx)) { - await _executeAction( - behaviourSources, - fp.find(a => a.name === trig.actionName)(actions), - createOptions(trig.optionsCreator, ctx), - ); - } - }); - } -}; - -const validateSources = (behaviourSources, actions) => { - const declaredSources = $(actions, [ - fp.uniqBy(a => a.behaviourSource), - fp.map(a => a.behaviourSource), - ]); - - const suppliedSources = fp.keys(behaviourSources); - - const missingSources = fp.difference( - declaredSources, suppliedSources, - ); - - if (missingSources.length > 0) { - throw new BadRequestError(`Declared behaviour sources are not supplied: ${fp.join(', ', missingSources)}`); - } - - const missingBehaviours = $(actions, [ - fp.filter(a => !fp.isFunction(behaviourSources[a.behaviourSource][a.behaviourName])), - fp.map(a => `Action: ${a.name} : ${a.behaviourSource}.${a.behaviourName}`), - ]); - - if (missingBehaviours.length > 0) { - throw new NotFoundError(`Missing behaviours: could not find behaviour functions: ${fp.join(', ', missingBehaviours)}`); - } -}; - -const retrieve = async (app) => { - const transactionFiles = await app.datastore.getFolderContents( - TRANSACTIONS_FOLDER, - ); - - let transactions = []; - - if (fp.some(isBuildIndexFolder)(transactionFiles)) { - const buildIndexFolder = fp.find(isBuildIndexFolder)(transactionFiles); - - transactions = await retrieveBuildIndexTransactions( - app, - joinKey(TRANSACTIONS_FOLDER, buildIndexFolder), - ); - } - - if (transactions.length > 0) return transactions; - - return await retrieveStandardTransactions( - app, transactionFiles, - ); -}; - -const retrieveBuildIndexTransactions = async (app, buildIndexFolder) => { - const childFolders = await app.datastore.getFolderContents(buildIndexFolder); - if (childFolders.length === 0) { - // cleanup - await app.datastore.deleteFolder(buildIndexFolder); - return []; - } - - const getTransactionFiles = async (childFolderIndex = 0) => { - if (childFolderIndex >= childFolders.length) return []; - - const childFolderKey = joinKey(buildIndexFolder, childFolders[childFolderIndex]); - const files = await app.datastore.getFolderContents( - childFolderKey, - ); - - if (files.length === 0) { - await app.datastore.deleteFolder(childFolderKey); - return await getTransactionFiles(childFolderIndex + 1); - } - - return { childFolderKey, files }; - }; - - const transactionFiles = await getTransactionFiles(); - - if (transactionFiles.files.length === 0) return []; - - const transactions = $(transactionFiles.files, [ - fp.map(parseTransactionId), - ]); - - for (const t of transactions) { - const transactionContent = await app.datastore.loadJson( - joinKey( - transactionFiles.childFolderKey, - t.fullId, - ), - ); - t.record = await _load(app, transactionContent.recordKey); - } - - transactions.indexNode = $(buildIndexFolder, [ - getLastPartInKey, - nodeKeyHashFromBuildFolder, - getNodeFromNodeKeyHash(app.hierarchy), - ]); - - transactions.folderKey = transactionFiles.childFolderKey; - - return transactions; -}; - -const retrieveStandardTransactions = async (app, transactionFiles) => { - const transactionIds = $(transactionFiles, [ - fp.filter(f => f !== LOCK_FILENAME - && !isBuildIndexFolder(f)), - fp.map(parseTransactionId), - ]); - - const transactionIdsByRecord = $(transactionIds, [ - fp.groupBy('recordId'), - ]); - - const dedupedTransactions = []; - - const verify = async (t) => { - if (t.verified === true) return t; - - const id = getTransactionId( - t.recordId, - t.transactionType, - t.uniqueId, - ); - - const transaction = await app.datastore.loadJson( - joinKey(TRANSACTIONS_FOLDER, id), - ); - - if (isDelete(t)) { - t.record = transaction.record; - t.verified = true; - return t; - } - - const rec = await _load( - app, - transaction.recordKey, - ); - if (rec.transactionId === id) { - t.record = rec; - if (transaction.oldRecord) { t.oldRecord = transaction.oldRecord; } - t.verified = true; - } else { - t.verified = false; - } - - return t; - }; - - const pickOne = async (trans, forType) => { - const transForType = fp.filter(forType)(trans); - if (transForType.length === 1) { - const t = await verify(transForType[0]); - return (t.verified === true ? t : null); - } - for (let t of transForType) { - t = await verify(t); - if (t.verified === true) { return t; } - } - - return null; - }; - - for (const recordId in transactionIdsByRecord) { - const transIdsForRecord = transactionIdsByRecord[recordId]; - if (transIdsForRecord.length === 1) { - const t = await verify(transIdsForRecord[0]); - if (t.verified) { dedupedTransactions.push(t); } - continue; - } - if (fp.some(isDelete)(transIdsForRecord)) { - const t = await verify(fp.find(isDelete)(transIdsForRecord)); - if (t.verified) { dedupedTransactions.push(t); } - continue; - } - if (fp.some(isUpdate)(transIdsForRecord)) { - const upd = await pickOne(transIdsForRecord, isUpdate); - if (isSomething(upd) && upd.verified) { dedupedTransactions.push(upd); } - continue; - } - if (fp.some(isCreate)(transIdsForRecord)) { - const cre = await pickOne(transIdsForRecord, isCreate); - if (isSomething(cre)) { dedupedTransactions.push(cre); } - continue; - } - } - - const duplicates = $(transactionIds, [ - fp.filter(t => none(ddt => ddt.uniqueId === t.uniqueId)(dedupedTransactions)), - ]); - - - const deletePromises = fp.map(t => app.datastore.deleteFile( - joinKey( - TRANSACTIONS_FOLDER, - getTransactionId( - t.recordId, - t.transactionType, - t.uniqueId, - ), - ), - ))(duplicates); - - await Promise.all(deletePromises); - - return dedupedTransactions; -}; - -const parseTransactionId = (id) => { - const splitId = fp.split(idSep)(id); - return ({ - recordId: splitId[0], - transactionType: splitId[1], - uniqueId: splitId[2], - fullId: id, - }); -}; - -const getRelevantAncestorIndexes = (hierarchy, record) => { - const key = record.key; - const keyParts = splitKey(key); - const nodeId = getRecordNodeId(key); - - const flatHierarchy = _.orderBy(getFlattenedHierarchy(hierarchy), - [node => node.pathRegx().length], - ['desc']); - - const makeindexNodeAndDir_ForAncestorIndex = (indexNode, parentRecordDir) => makeIndexNodeAndDir(indexNode, joinKey(parentRecordDir, indexNode.name)); - - const traverseAncestorIndexesInPath = () => fp.reduce((acc, part) => { - const currentIndexKey = joinKey(acc.lastIndexKey, part); - acc.lastIndexKey = currentIndexKey; - const testPathRegx = p => new RegExp(`${p.pathRegx()}$`).test(currentIndexKey); - const nodeMatch = fp.find(testPathRegx)(flatHierarchy); - - if (isNothing(nodeMatch)) { return acc; } - - if (!isRecord(nodeMatch) - || nodeMatch.indexes.length === 0) { return acc; } - - const indexes = $(nodeMatch.indexes, [ - fp.filter(i => i.indexType === indexTypes.ancestor - && (i.allowedRecordNodeIds.length === 0 - || fp.includes(nodeId)(i.allowedRecordNodeIds))), - ]); - - const currentRecordDir = getRecordInfo(hierarchy, currentIndexKey).dir; - - fp.each(v => acc.nodesAndKeys.push( - makeindexNodeAndDir_ForAncestorIndex(v, currentRecordDir), - ))(indexes); - - return acc; - }, { lastIndexKey: '', nodesAndKeys: [] })(keyParts).nodesAndKeys; - - const rootIndexes = $(flatHierarchy, [ - fp.filter(n => isGlobalIndex(n) && recordNodeIdIsAllowed(n)(nodeId)), - fp.map(i => makeIndexNodeAndDir( - i, - getIndexDir(hierarchy, i.nodeKey()))), - ]); - - return fp.union(traverseAncestorIndexesInPath())(rootIndexes); -}; - -const getRelevantReverseReferenceIndexes = (hierarchy, record) => $(record.key, [ - getExactNodeForKey(hierarchy), - n => n.fields, - fp.filter(f => f.type === 'reference' - && isSomething(record[f.name]) - && isNonEmptyString(record[f.name].key)), - fp.map(f => $(f.typeOptions.reverseIndexNodeKeys, [ - fp.map(n => ({ - recordNode: getNode(hierarchy, n), - field: f, - })), - ])), - fp.flatten, - fp.map(n => makeIndexNodeAndDir( - n.recordNode, - joinKey( - getRecordInfo(hierarchy, record[n.field.name].key).dir, - n.recordNode.name), - )), -]); - -const makeIndexNodeAndDir = (indexNode, indexDir) => ({ indexNode, indexDir }); - -// adapted from https://github.com/dex4er/js-promise-writable - // Thank you :) - const promiseWriteableStream = stream => { - - let _errored; - - const _errorHandler = err => { - _errored = err; - }; - - stream.on("error", _errorHandler); - - const write = chunk => { - let rejected = false; - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err); - } - - if (!stream.writable || stream.closed || stream.destroyed) { - return reject(new Error("write after end")); - } - - const writeErrorHandler = err => { - _errored = undefined; - rejected = true; - reject(err); - }; - - stream.once("error", writeErrorHandler); - - const canWrite = stream.write(chunk); - - stream.removeListener("error", writeErrorHandler); - - if (canWrite) { - if (!rejected) { - resolve(chunk.length); - } - } else { - const errorHandler = err => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const drainHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const closeHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const finishHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const removeListeners = () => { - stream.removeListener("close", closeHandler); - stream.removeListener("drain", drainHandler); - stream.removeListener("error", errorHandler); - stream.removeListener("finish", finishHandler); - }; - - stream.on("close", closeHandler); - stream.on("drain", drainHandler); - stream.on("error", errorHandler); - stream.on("finish", finishHandler); - } - }) - }; - - const end = () => { - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err); - } - - if (!stream.writable || stream.closed || stream.destroyed) { - return resolve(); - } - - const finishHandler = () => { - removeListeners(); - resolve(); - }; - - const errorHandler = (err) => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const removeListeners = () => { - stream.removeListener("error", errorHandler); - stream.removeListener("finish", finishHandler); - }; - - stream.on("finish", finishHandler); - stream.on("error", errorHandler); - - stream.end(); - }) - }; - - return {write, end}; - }; - -const applyToShard = async (hierarchy, store, indexDir, - indexNode, indexShardKey, recordsToWrite, keysToRemove) => { - const createIfNotExists = recordsToWrite.length > 0; - const writer = await getWriter(hierarchy, store, indexDir, indexShardKey, indexNode, createIfNotExists); - if (writer === SHARD_DELETED) return; - - await writer.updateIndex(recordsToWrite, keysToRemove); - await swapTempFileIn(store, indexShardKey); -}; - -const SHARD_DELETED = 'SHARD_DELETED'; -const getWriter = async (hierarchy, store, indexDir, indexedDataKey, indexNode, createIfNotExists) => { - let readableStream = null; - - if (isShardedIndex(indexNode)) { - await ensureShardNameIsInShardMap(store, indexDir, indexedDataKey); - if(!await store.exists(indexedDataKey)) { - if (await store.exists(getParentKey(indexedDataKey))) { - await store.createFile(indexedDataKey, ""); - } else { - return SHARD_DELETED; - } - } - } - - try { - - readableStream = promiseReadableStream( - await store.readableFileStream(indexedDataKey) - ); - - } catch (e) { - - if (await store.exists(indexedDataKey)) { - throw e; - } else { - if (createIfNotExists) { - if(await store.exists(getParentKey(indexedDataKey))) { - await store.createFile(indexedDataKey, ''); - } else { - return SHARD_DELETED; - } - } else { - return SHARD_DELETED; - } - - readableStream = promiseReadableStream( - await store.readableFileStream(indexedDataKey) - ); - - } - } - - const writableStream = promiseWriteableStream( - await store.writableFileStream(indexedDataKey + ".temp") - ); - - return getIndexWriter( - hierarchy, indexNode, - readableStream, writableStream - ); -}; - -const swapTempFileIn = async (store, indexedDataKey, isRetry = false) => { - const tempFile = `${indexedDataKey}.temp`; - try { - await store.deleteFile(indexedDataKey); - } catch (e) { - // ignore failure, incase it has not been created yet - - // if parent folder does not exist, assume that this index - // should not be there - if(!await store.exists(getParentKey(indexedDataKey))) { - return; - } - } - try { - await store.renameFile(tempFile, indexedDataKey); - } catch (e) { - // retrying in case delete failure was for some other reason - if (!isRetry) { - await swapTempFileIn(store, indexedDataKey, true); - } else { - throw new Error("Failed to swap in index filed: " + e.message); - } - } -}; - -const executeTransactions = app => async (transactions) => { - const recordsByShard = mappedRecordsByIndexShard(app.hierarchy, transactions); - - for (const shard of fp.keys(recordsByShard)) { - await applyToShard( - app.hierarchy, app.datastore, - recordsByShard[shard].indexDir, - recordsByShard[shard].indexNode, - shard, - recordsByShard[shard].writes, - recordsByShard[shard].removes, - ); - } -}; - -const mappedRecordsByIndexShard = (hierarchy, transactions) => { - const updates = getUpdateTransactionsByShard( - hierarchy, transactions, - ); - - const created = getCreateTransactionsByShard( - hierarchy, transactions, - ); - const deletes = getDeleteTransactionsByShard( - hierarchy, transactions, - ); - - const indexBuild = getBuildIndexTransactionsByShard( - hierarchy, - transactions, - ); - - const toRemove = [ - ...deletes, - ...updates.toRemove, - ]; - - const toWrite = [ - ...created, - ...updates.toWrite, - ...indexBuild, - ]; - - const transByShard = {}; - - const initialiseShard = (t) => { - if (fp.isUndefined(transByShard[t.indexShardKey])) { - transByShard[t.indexShardKey] = { - writes: [], - removes: [], - indexDir: t.indexDir, - indexNodeKey: t.indexNode.nodeKey(), - indexNode: t.indexNode, - }; - } - }; - - for (const trans of toWrite) { - initialiseShard(trans); - transByShard[trans.indexShardKey].writes.push( - trans.mappedRecord.result, - ); - } - - for (const trans of toRemove) { - initialiseShard(trans); - transByShard[trans.indexShardKey].removes.push( - trans.mappedRecord.result.key, - ); - } - - return transByShard; -}; - -const getUpdateTransactionsByShard = (hierarchy, transactions) => { - const updateTransactions = $(transactions, [fp.filter(isUpdate)]); - - const evaluateIndex = (record, indexNodeAndPath) => { - const mappedRecord = evaluate(record)(indexNodeAndPath.indexNode); - return ({ - mappedRecord, - indexNode: indexNodeAndPath.indexNode, - indexDir: indexNodeAndPath.indexDir, - indexShardKey: getIndexedDataKey( - indexNodeAndPath.indexNode, - indexNodeAndPath.indexDir, - mappedRecord.result, - ), - }); - }; - - const getIndexNodesToApply = indexFilter => (t, indexes) => $(indexes, [ - fp.map(n => ({ - old: evaluateIndex(t.oldRecord, n), - new: evaluateIndex(t.record, n), - })), - fp.filter(indexFilter), - ]); - - const toRemoveFilter = (n, isUnreferenced) => n.old.mappedRecord.passedFilter === true - && (n.new.mappedRecord.passedFilter === false - || isUnreferenced); - - const toAddFilter = (n, isNewlyReferenced) => (n.old.mappedRecord.passedFilter === false - || isNewlyReferenced) - && n.new.mappedRecord.passedFilter === true; - - const toUpdateFilter = n => n.new.mappedRecord.passedFilter === true - && n.old.mappedRecord.passedFilter === true - && !fp.isEqual(n.old.mappedRecord.result, - n.new.mappedRecord.result); - - const toRemove = []; - const toWrite = []; - - for (const t of updateTransactions) { - const ancestorIdxs = getRelevantAncestorIndexes( - hierarchy, t.record, - ); - - const referenceChanges = diffReverseRefForUpdate( - hierarchy, t.oldRecord, t.record, - ); - - // old records to remove (filtered out) - const filteredOut_toRemove = _.union( - getIndexNodesToApply(toRemoveFilter)(t, ancestorIdxs), - // still referenced - check filter - getIndexNodesToApply(toRemoveFilter)(t, referenceChanges.notChanged), - // un referenced - remove if in there already - getIndexNodesToApply(n => toRemoveFilter(n, true))(t, referenceChanges.unReferenced), - ); - - // new records to add (filtered in) - const filteredIn_toAdd = _.union( - getIndexNodesToApply(toAddFilter)(t, ancestorIdxs), - // newly referenced - check filter - getIndexNodesToApply(n => toAddFilter(n, true))(t, referenceChanges.newlyReferenced), - // reference unchanged - rerun filter in case something else changed - getIndexNodesToApply(toAddFilter)(t, referenceChanges.notChanged), - ); - - const changed = _.union( - getIndexNodesToApply(toUpdateFilter)(t, ancestorIdxs), - // still referenced - recheck filter - getIndexNodesToApply(toUpdateFilter)(t, referenceChanges.notChanged), - ); - - const shardKeyChanged = $(changed, [ - fp.filter(c => c.old.indexShardKey !== c.new.indexShardKey), - ]); - - const changedInSameShard = $(shardKeyChanged, [ - fp.difference(changed), - ]); - - for (const res of shardKeyChanged) { - fp.pull(res)(changed); - filteredOut_toRemove.push(res); - filteredIn_toAdd.push(res); - } - - toRemove.push( - $(filteredOut_toRemove, [ - fp.map(i => i.old), - ]), - ); - - toWrite.push( - $(filteredIn_toAdd, [ - fp.map(i => i.new), - ]), - ); - - toWrite.push( - $(changedInSameShard, [ - fp.map(i => i.new), - ]), - ); - } - - return ({ - toRemove: fp.flatten(toRemove), - toWrite: fp.flatten(toWrite), - }); -}; - -const getBuildIndexTransactionsByShard = (hierarchy, transactions) => { - const buildTransactions = $(transactions, [fp.filter(isBuildIndex)]); - if (!isNonEmptyArray(buildTransactions)) return []; - const indexNode = transactions.indexNode; - - const getIndexDirs = (t) => { - if (isGlobalIndex(indexNode)) { - return [indexNode.nodeKey()]; - } - - if (isReferenceIndex(indexNode)) { - const recordNode = getExactNodeForKey(hierarchy)(t.record.key); - const refFields = $(recordNode.fields, [ - fp.filter(fieldReversesReferenceToIndex(indexNode)), - ]); - const indexDirs = []; - for (const refField of refFields) { - const refValue = t.record[refField.name]; - if (isSomething(refValue) - && isNonEmptyString(refValue.key)) { - const indexDir = joinKey( - getRecordInfo(hierarchy, refValue.key).dir, - indexNode.name, - ); - - if (!fp.includes(indexDir)(indexDirs)) { indexDirs.push(indexDir); } - } - } - return indexDirs; - } - - const indexKey = joinKey( - getActualKeyOfParent( - indexNode.parent().nodeKey(), - t.record.key, - ), - indexNode.name, - ); - - return [getIndexDir(hierarchy, indexKey)]; - }; - - return $(buildTransactions, [ - fp.map((t) => { - const mappedRecord = evaluate(t.record)(indexNode); - if (!mappedRecord.passedFilter) return null; - const indexDirs = getIndexDirs(t); - return $(indexDirs, [ - fp.map(indexDir => ({ - mappedRecord, - indexNode, - indexDir, - indexShardKey: getIndexedDataKey( - indexNode, - indexDir, - mappedRecord.result, - ), - })), - ]); - }), - fp.flatten, - fp.filter(isSomething), - ]); -}; - -const get_Create_Delete_TransactionsByShard = pred => (hierarchy, transactions) => { - const createTransactions = $(transactions, [fp.filter(pred)]); - - const getIndexNodesToApply = (t, indexes) => $(indexes, [ - fp.map((n) => { - const mappedRecord = evaluate(t.record)(n.indexNode); - return ({ - mappedRecord, - indexNode: n.indexNode, - indexDir: n.indexDir, - indexShardKey: getIndexedDataKey( - n.indexNode, - n.indexDir, - mappedRecord.result, - ), - }); - }), - fp.filter(n => n.mappedRecord.passedFilter), - ]); - - const allToApply = []; - - for (const t of createTransactions) { - const ancestorIdxs = getRelevantAncestorIndexes(hierarchy, t.record); - const reverseRef = getRelevantReverseReferenceIndexes(hierarchy, t.record); - - allToApply.push( - getIndexNodesToApply(t, ancestorIdxs), - ); - allToApply.push( - getIndexNodesToApply(t, reverseRef), - ); - } - - return fp.flatten(allToApply); -}; - -const getDeleteTransactionsByShard = get_Create_Delete_TransactionsByShard(isDelete); - -const getCreateTransactionsByShard = get_Create_Delete_TransactionsByShard(isCreate); - -const diffReverseRefForUpdate = (appHierarchy, oldRecord, newRecord) => { - const oldIndexes = getRelevantReverseReferenceIndexes( - appHierarchy, oldRecord, - ); - const newIndexes = getRelevantReverseReferenceIndexes( - appHierarchy, newRecord, - ); - - const unReferenced = fp.differenceBy( - i => i.indexDir, - oldIndexes, newIndexes, - ); - - const newlyReferenced = fp.differenceBy( - i => i.indexDir, - newIndexes, oldIndexes, - ); - - const notChanged = fp.intersectionBy( - i => i.indexDir, - newIndexes, oldIndexes, - ); - - return { - unReferenced, - newlyReferenced, - notChanged, - }; -}; - -const cleanup = async (app) => { - const lock = await getTransactionLock(app); - if (isNolock(lock)) return; - - try { - const transactions = await retrieve(app); - if (transactions.length > 0) { - await executeTransactions(app)(transactions); - - const folder = transactions.folderKey - ? transactions.folderKey - : TRANSACTIONS_FOLDER; - - const deleteFiles = $(transactions, [ - fp.map(t => joinKey( - folder, - getTransactionId( - t.recordId, t.transactionType, - t.uniqueId, - ), - )), - fp.map(app.datastore.deleteFile), - ]); - - await Promise.all(deleteFiles); - } - } finally { - await releaseLock(app, lock); - } -}; - -const getTransactionLock = async app => await getLock( - app, LOCK_FILE_KEY, - timeoutMilliseconds, maxLockRetries, -); - -const initialiseData = async (datastore, applicationDefinition, accessLevels) => { - await datastore.createFolder(configFolder); - await datastore.createJson(appDefinitionFile, applicationDefinition); - - await initialiseRootCollections(datastore, applicationDefinition.hierarchy); - await initialiseRootIndexes(datastore, applicationDefinition.hierarchy); - - await datastore.createFolder(TRANSACTIONS_FOLDER); - - await datastore.createFolder(AUTH_FOLDER); - - await datastore.createJson(USERS_LIST_FILE, []); - - await datastore.createJson( - ACCESS_LEVELS_FILE, - accessLevels ? accessLevels : { version: 0, levels: [] }); - - await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy); -}; - -const initialiseRootIndexes = async (datastore, hierarchy) => { - const flathierarchy = getFlattenedHierarchy(hierarchy); - const globalIndexes = $(flathierarchy, [ - fp.filter(isGlobalIndex), - ]); - - for (const index of globalIndexes) { - if (!await datastore.exists(index.nodeKey())) { - await initialiseIndex(datastore, '', index); - } - } -}; - -const initialiseRootSingleRecords = async (datastore, hierarchy) => { - const app = { - publish:()=>{}, - cleanupTransactions: () => {}, - datastore, hierarchy - }; - - const flathierarchy = getFlattenedHierarchy(hierarchy); - const singleRecords = $(flathierarchy, [ - fp.filter(isSingleRecord), - ]); - - for (let record of singleRecords) { - await datastore.createFolder(record.nodeKey()); - const result = _getNew(record, ""); - await _save(app,result); - } -}; - -const getDatabaseManager = databaseManager => ({ - createEmptyMasterDb: createEmptyMasterDb(databaseManager), - createEmptyInstanceDb: createEmptyInstanceDb(databaseManager), - getInstanceDbRootConfig: databaseManager.getInstanceDbRootConfig, - masterDatastoreConfig: getMasterDatastoreConfig(databaseManager), - getInstanceDatastoreConfig: getInstanceDatastoreConfig(databaseManager), -}); - -const getMasterDatastoreConfig = databaseManager => databaseManager.getDatastoreConfig('master'); - -const getInstanceDatastoreConfig = databaseManager => (applicationId, instanceId) => databaseManager.getDatastoreConfig( - applicationId, instanceId, -); - -const createEmptyMasterDb = databaseManager => async () => await databaseManager.createEmptyDb('master'); - -const createEmptyInstanceDb = databaseManager => async (applicationId, instanceId) => { - if (isNothing(applicationId)) { throw new Error('CreateDb: application id not supplied'); } - if (isNothing(instanceId)) { throw new Error('CreateDb: instance id not supplied'); } - - return await databaseManager.createEmptyDb( - applicationId, - instanceId, - ); -}; - -const getAppApis = async (store, behaviourSources = null, - cleanupTransactions = null, - getEpochTime = null, - crypto = null, - appDefinition = null) => { - - store = setupDatastore(store); - - if(!appDefinition) - appDefinition = await getApplicationDefinition(store)(); - - if(!behaviourSources) - behaviourSources = await getBehaviourSources(store); - - const eventAggregator = createEventAggregator(); - - const app = { - datastore:store, - crypto, - publish:eventAggregator.publish, - hierarchy:appDefinition.hierarchy, - actions:appDefinition.actions - }; - - const templateApi = getTemplateApi(app); - - app.cleanupTransactions = isSomething(cleanupTransactions) - ? cleanupTransactions - : async () => await cleanup(app); - - app.getEpochTime = isSomething(getEpochTime) - ? getEpochTime - : async () => (new Date()).getTime(); - - const recordApi = getRecordApi(app); - const collectionApi = getCollectionApi(app); - const indexApi = getIndexApi(app); - const authApi = getAuthApi(app); - const actionsApi = getActionsApi(app); - - const authenticateAs = async (username, password) => { - app.user = await authApi.authenticate(username, password); - }; - - const withFullAccess = () => - userWithFullAccess(app); - - const asUser = (user) => { - app.user = user; - }; - - let apis = { - recordApi, - templateApi, - collectionApi, - indexApi, - authApi, - actionsApi, - subscribe: eventAggregator.subscribe, - authenticateAs, - withFullAccess, - asUser - }; - - apis.actions = initialiseActions( - eventAggregator.subscribe, - behaviourSources, - appDefinition.actions, - appDefinition.triggers, - apis); - - - return apis; -}; - -const userWithFullAccess = (app) => { - app.user = { - name: "app", - permissions : generateFullPermissions(app), - isUser:false, - temp:false - }; - return app.user; -}; - -exports.common = index; -exports.default = getAppApis; -exports.events = events; -exports.eventsList = eventsList; -exports.getActionsApi = getActionsApi; -exports.getAppApis = getAppApis; -exports.getAuthApi = getAuthApi; -exports.getCollectionApi = getCollectionApi; -exports.getDatabaseManager = getDatabaseManager; -exports.getIndexApi = getIndexApi; -exports.getRecordApi = getRecordApi; -exports.getTemplateApi = getTemplateApi; -exports.hierarchy = hierarchy; -exports.initialiseData = initialiseData; -exports.setupDatastore = setupDatastore; -exports.userWithFullAccess = userWithFullAccess; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"budibase-core.cjs.js","sources":["../src/common/events.js","../src/common/errors.js","../src/common/apiWrapper.js","../src/common/lock.js","../src/common/index.js","../src/common/validationCommon.js","../src/indexing/evaluate.js","../src/templateApi/indexes.js","../src/templateApi/hierarchy.js","../src/types/typeHelpers.js","../src/types/string.js","../src/types/bool.js","../src/types/number.js","../src/types/datetime.js","../src/types/array.js","../src/types/reference.js","../src/types/file.js","../src/types/index.js","../src/authApi/authCommon.js","../src/authApi/isAuthorized.js","../src/authApi/permissions.js","../src/recordApi/getNew.js","../src/indexing/allIds.js","../src/recordApi/recordInfo.js","../src/recordApi/load.js","../src/indexing/promiseReadableStream.js","../src/indexing/sharding.js","../src/indexing/indexSchemaCreator.js","../node_modules/rollup-plugin-node-globals/src/global.js","../node_modules/buffer-es6/base64.js","../node_modules/buffer-es6/ieee754.js","../node_modules/buffer-es6/isArray.js","../node_modules/buffer-es6/index.js","../node_modules/rollup-plugin-node-builtins/src/es6/string-decoder.js","../src/indexing/serializer.js","../src/indexing/read.js","../src/indexApi/getIndexDir.js","../src/indexApi/listItems.js","../src/recordApi/getContext.js","../src/recordApi/validate.js","../src/collectionApi/initialise.js","../src/transactions/transactionsCommon.js","../src/transactions/create.js","../src/indexing/initialiseIndex.js","../src/recordApi/save.js","../src/collectionApi/delete.js","../src/recordApi/delete.js","../src/recordApi/uploadFile.js","../src/recordApi/downloadFile.js","../src/recordApi/customId.js","../src/recordApi/index.js","../src/collectionApi/getAllowedRecordTypes.js","../src/collectionApi/index.js","../src/indexApi/buildIndex.js","../src/indexApi/aggregates.js","../src/indexApi/index.js","../src/templateApi/createNodes.js","../src/templateApi/fields.js","../src/templateApi/recordValidationRules.js","../src/templateApi/createActions.js","../src/templateApi/validateAggregate.js","../src/templateApi/validate.js","../src/templateApi/getApplicationDefinition.js","../src/templateApi/saveApplicationHierarchy.js","../src/templateApi/saveActionsAndTriggers.js","../src/templateApi/getBehaviourSources.js","../src/templateApi/index.js","../src/authApi/getUsers.js","../src/authApi/loadAccessLevels.js","../src/authApi/authenticate.js","../src/authApi/createTemporaryAccess.js","../src/authApi/validateUser.js","../src/authApi/getNewUser.js","../src/authApi/setPassword.js","../src/authApi/createUser.js","../src/authApi/enableUser.js","../src/authApi/getNewAccessLevel.js","../src/authApi/validateAccessLevels.js","../src/authApi/saveAccessLevels.js","../src/authApi/generateFullPermissions.js","../src/authApi/setUserAccessLevels.js","../src/authApi/index.js","../src/actionsApi/execute.js","../src/actionsApi/index.js","../src/appInitialise/eventAggregator.js","../src/appInitialise/index.js","../src/common/compileCode.js","../src/actionsApi/initialise.js","../src/transactions/retrieve.js","../src/indexing/relevant.js","../src/indexing/promiseWritableStream.js","../src/indexing/apply.js","../src/transactions/execute.js","../src/transactions/cleanup.js","../src/appInitialise/initialiseData.js","../src/appInitialise/databaseManager.js","../src/index.js"],"sourcesContent":["import { union, reduce } from 'lodash/fp';\n\nconst commonPlus = extra => union(['onBegin', 'onComplete', 'onError'])(extra);\n\nconst common = () => commonPlus([]);\n\nconst _events = {\n  recordApi: {\n    save: commonPlus([\n      'onInvalid',\n      'onRecordUpdated',\n      'onRecordCreated']),\n    delete: common(),\n    getContext: common(),\n    getNew: common(),\n    load: common(),\n    validate: common(),\n    uploadFile: common(),\n    downloadFile: common(),\n  },\n  indexApi: {\n    buildIndex: common(),\n    listItems: common(),\n    delete: common(),\n    aggregates: common(),\n  },\n  collectionApi: {\n    getAllowedRecordTypes: common(),\n    initialise: common(),\n    delete: common(),\n  },\n  authApi: {\n    authenticate: common(),\n    authenticateTemporaryAccess: common(),\n    createTemporaryAccess: common(),\n    createUser: common(),\n    enableUser: common(),\n    disableUser: common(),\n    loadAccessLevels: common(),\n    getNewAccessLevel: common(),\n    getNewUser: common(),\n    getNewUserAuth: common(),\n    getUsers: common(),\n    saveAccessLevels: common(),\n    isAuthorized: common(),\n    changeMyPassword: common(),\n    setPasswordFromTemporaryCode: common(),\n    scorePassword: common(),\n    isValidPassword: common(),\n    validateUser: common(),\n    validateAccessLevels: common(),\n    setUserAccessLevels: common(),\n  },\n  templateApi: {\n    saveApplicationHierarchy: common(),\n    saveActionsAndTriggers: common(),\n  },\n  actionsApi: {\n    execute: common(),\n  },\n};\n\nconst _eventsList = [];\n\nconst makeEvent = (area, method, name) => `${area}:${method}:${name}`;\n\nfor (const areaKey in _events) {\n  for (const methodKey in _events[areaKey]) {\n    _events[areaKey][methodKey] = reduce((obj, s) => {\n      obj[s] = makeEvent(areaKey, methodKey, s);\n      return obj;\n    },\n    {})(_events[areaKey][methodKey]);\n  }\n}\n\n\nfor (const areaKey in _events) {\n  for (const methodKey in _events[areaKey]) {\n    for (const name in _events[areaKey][methodKey]) {\n      _eventsList.push(\n        _events[areaKey][methodKey][name],\n      );\n    }\n  }\n}\n\n\nexport const events = _events;\n\nexport const eventsList = _eventsList;\n\nexport default { events: _events, eventsList: _eventsList };\n","export class BadRequestError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 400;\n    }\n}\n\nexport class UnauthorisedError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 401;\n    }\n}\n\nexport class ForbiddenError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 403;\n    }\n}\n\nexport class NotFoundError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 404;\n    }\n}\n\nexport class ConflictError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 409;\n    }\n}","import { cloneDeep, isUndefined } from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { UnauthorisedError } from './errors';\n\nexport const apiWrapper = async (app, eventNamespace, isAuthorized, eventContext, func, ...params) => {\n  pushCallStack(app, eventNamespace);\n\n  if (!isAuthorized(app)) {\n    handleNotAuthorized(app, eventContext, eventNamespace);\n    return;\n  }\n\n  const startDate = Date.now();\n  const elapsed = () => (Date.now() - startDate);\n\n  try {\n    await app.publish(\n      eventNamespace.onBegin,\n      eventContext,\n    );\n\n    const result = await func(...params);\n\n    await publishComplete(app, eventContext, eventNamespace, elapsed, result);\n    return result;\n  } catch (error) {\n    await publishError(app, eventContext, eventNamespace, elapsed, error);\n    throw error;\n  }\n};\n\nexport const apiWrapperSync = (app, eventNamespace, isAuthorized, eventContext, func, ...params) => {\n  pushCallStack(app, eventNamespace);\n\n  if (!isAuthorized(app)) {\n    handleNotAuthorized(app, eventContext, eventNamespace);\n    return;\n  }\n\n  const startDate = Date.now();\n  const elapsed = () => (Date.now() - startDate);\n\n  try {\n    app.publish(\n      eventNamespace.onBegin,\n      eventContext,\n    );\n\n    const result = func(...params);\n\n    publishComplete(app, eventContext, eventNamespace, elapsed, result);\n    return result;\n  } catch (error) {\n    publishError(app, eventContext, eventNamespace, elapsed, error);\n    throw error;\n  }\n};\n\nconst handleNotAuthorized = (app, eventContext, eventNamespace) => {\n  const err = new UnauthorisedError(`Unauthorized: ${eventNamespace}`);\n  publishError(app, eventContext, eventNamespace, () => 0, err);\n  throw err;\n};\n\nconst pushCallStack = (app, eventNamespace, seedCallId) => {\n  const callId = generate();\n\n  const createCallStack = () => ({\n    seedCallId: !isUndefined(seedCallId)\n      ? seedCallId\n      : callId,\n    threadCallId: callId,\n    stack: [],\n  });\n\n  if (isUndefined(app.calls)) {\n    app.calls = createCallStack();\n  }\n\n  app.calls.stack.push({\n    namespace: eventNamespace,\n    callId,\n  });\n};\n\nconst popCallStack = (app) => {\n  app.calls.stack.pop();\n  if (app.calls.stack.length === 0) {\n    delete app.calls;\n  }\n};\n\nconst publishError = async (app, eventContext, eventNamespace, elapsed, err) => {\n  const ctx = cloneDeep(eventContext);\n  ctx.error = err;\n  ctx.elapsed = elapsed();\n  await app.publish(\n    eventNamespace.onError,\n    ctx,\n  );\n  popCallStack(app);\n};\n\nconst publishComplete = async (app, eventContext, eventNamespace, elapsed, result) => {\n  const endcontext = cloneDeep(eventContext);\n  endcontext.result = result;\n  endcontext.elapsed = elapsed();\n  await app.publish(\n    eventNamespace.onComplete,\n    endcontext,\n  );\n  popCallStack(app);\n  return result;\n};\n\nexport default apiWrapper;\n","import { split } from 'lodash/fp';\nimport { $ } from './index';\n\nconst lockOverlapMilliseconds = 10;\n\nexport const getLock = async (app, lockFile, timeoutMilliseconds, maxLockRetries, retryCount = 0) => {\n  try {\n    const timeout = (await app.getEpochTime())\n            + timeoutMilliseconds;\n\n    const lock = {\n      timeout,\n      key: lockFile,\n      totalTimeout: timeoutMilliseconds,\n    };\n\n    await app.datastore.createFile(\n      lockFile,\n      getLockFileContent(\n        lock.totalTimeout,\n        lock.timeout,\n      ),\n    );\n\n    return lock;\n  } catch (e) {\n    if (retryCount == maxLockRetries) { return NO_LOCK; }\n\n    const lock = parseLockFileContent(\n      lockFile,\n      await app.datastore.loadFile(lockFile),\n    );\n\n    const currentEpochTime = await app.getEpochTime();\n\n    if (currentEpochTime < lock.timeout) {\n      return NO_LOCK;\n    }\n\n    try {\n      await app.datastore.deleteFile(lockFile);\n    } catch (_) {\n      //empty\n    }\n\n    await sleepForRetry();\n\n    return await getLock(\n      app, lockFile, timeoutMilliseconds,\n      maxLockRetries, retryCount + 1,\n    );\n  }\n};\n\nexport const getLockFileContent = (totalTimeout, epochTime) => `${totalTimeout}:${epochTime.toString()}`;\n\nconst parseLockFileContent = (key, content) => $(content, [\n  split(':'),\n  parts => ({\n    totalTimeout: new Number(parts[0]),\n    timeout: new Number(parts[1]),\n    key,\n  }),\n]);\n\nexport const releaseLock = async (app, lock) => {\n  const currentEpochTime = await app.getEpochTime();\n  // only release if not timedout\n  if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) {\n    try {\n      await app.datastore.deleteFile(lock.key);\n    } catch (_) {\n      //empty\n    }\n  }\n};\n\nexport const extendLock = async (app, lock) => {\n  const currentEpochTime = await app.getEpochTime();\n  // only release if not timedout\n  if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) {\n    try {\n      lock.timeout = currentEpochTime + lock.timeoutMilliseconds;\n      await app.datastore.updateFile(\n        lock.key,\n        getLockFileContent(lock.totalTimeout, lock.timeout),\n      );\n      return lock;\n    } catch (_) {\n      //empty\n    }\n  }\n  return NO_LOCK;\n};\n\nexport const NO_LOCK = 'no lock';\nexport const isNolock = id => id === NO_LOCK;\n\nconst sleepForRetry = () => new Promise(resolve => setTimeout(resolve, lockOverlapMilliseconds));\n","import {\n  \n  head, \n  tail, findIndex, startsWith, \n  dropRight, flow, takeRight, trim,\n  replace\n} from 'lodash';\nimport { \n  some, reduce, isEmpty, isArray, join,\n  isString, isInteger, isDate, toNumber,\n  isUndefined, isNaN, isNull, constant,\n  split, includes, filter\n} from 'lodash/fp';\nimport { events, eventsList } from './events';\nimport { apiWrapper } from './apiWrapper';\nimport {\n  getLock, NO_LOCK,\n  isNolock\n} from './lock';\n\n// this is the combinator function\nexport const $$ = (...funcs) => arg => flow(funcs)(arg);\n\n// this is the pipe function\nexport const $ = (arg, funcs) => $$(...funcs)(arg);\n\nexport const keySep = '/';\nconst trimKeySep = str => trim(str, keySep);\nconst splitByKeySep = str => split(keySep)(str);\nexport const safeKey = key => replace(`${keySep}${trimKeySep(key)}`, `${keySep}${keySep}`, keySep);\nexport const joinKey = (...strs) => {\n  const paramsOrArray = strs.length === 1 & isArray(strs[0])\n    ? strs[0] : strs;\n  return $(paramsOrArray, [\n    filter(s => !isUndefined(s) \n                && !isNull(s) \n                && s.toString().length > 0),\n    join(keySep),\n    safeKey\n  ]);\n};\nexport const splitKey = $$(trimKeySep, splitByKeySep);\nexport const getDirFomKey = $$(splitKey, dropRight, p => joinKey(...p));\nexport const getFileFromKey = $$(splitKey, takeRight, head);\n\nexport const configFolder = `${keySep}.config`;\nexport const fieldDefinitions = joinKey(configFolder, 'fields.json');\nexport const templateDefinitions = joinKey(configFolder, 'templates.json');\nexport const appDefinitionFile = joinKey(configFolder, 'appDefinition.json');\nexport const dirIndex = folderPath => joinKey(configFolder, 'dir', ...splitKey(folderPath), 'dir.idx');\nexport const getIndexKeyFromFileKey = $$(getDirFomKey, dirIndex);\n\nexport const ifExists = (val, exists, notExists) => (isUndefined(val)\n  ? isUndefined(notExists) ? (() => { })() : notExists()\n  : exists());\n\nexport const getOrDefault = (val, defaultVal) => ifExists(val, () => val, () => defaultVal);\n\nexport const not = func => val => !func(val);\nexport const isDefined = not(isUndefined);\nexport const isNonNull = not(isNull);\nexport const isNotNaN = not(isNaN);\n\nexport const allTrue = (...funcArgs) => val => reduce(\n  (result, conditionFunc) => (isNull(result) || result == true) && conditionFunc(val),\n  null)(funcArgs);\n\nexport const anyTrue = (...funcArgs) => val => reduce(\n  (result, conditionFunc) => result == true || conditionFunc(val),\n  null)(funcArgs);\n\nexport const insensitiveEquals = (str1, str2) => str1.trim().toLowerCase() === str2.trim().toLowerCase();\n\nexport const isSomething = allTrue(isDefined, isNonNull, isNotNaN);\nexport const isNothing = not(isSomething);\nexport const isNothingOrEmpty = v => isNothing(v) || isEmpty(v);\nexport const somethingOrGetDefault = getDefaultFunc => val => (isSomething(val) ? val : getDefaultFunc());\nexport const somethingOrDefault = (val, defaultVal) => somethingOrGetDefault(constant(defaultVal))(val);\n\nexport const mapIfSomethingOrDefault = (mapFunc, defaultVal) => val => (isSomething(val) ? mapFunc(val) : defaultVal);\n\nexport const mapIfSomethingOrBlank = mapFunc => mapIfSomethingOrDefault(mapFunc, '');\n\nexport const none = predicate => collection => !some(predicate)(collection);\n\nexport const all = predicate => collection => none(v => !predicate(v))(collection);\n\nexport const isNotEmpty = ob => !isEmpty(ob);\nexport const isAsync = fn => fn.constructor.name === 'AsyncFunction';\nexport const isNonEmptyArray = allTrue(isArray, isNotEmpty);\nexport const isNonEmptyString = allTrue(isString, isNotEmpty);\nexport const tryOr = failFunc => (func, ...args) => {\n  try {\n    return func.apply(null, ...args);\n  } catch (_) {\n    return failFunc();\n  }\n};\n\nexport const tryAwaitOr = failFunc => async (func, ...args) => {\n  try {\n    return await func.apply(null, ...args);\n  } catch (_) {\n    return await failFunc();\n  }\n};\n\nexport const defineError = (func, errorPrefix) => {\n  try {\n    return func();\n  } catch (err) {\n    err.message = `${errorPrefix} : ${err.message}`;\n    throw err;\n  }\n};\n\nexport const tryOrIgnore = tryOr(() => { });\nexport const tryAwaitOrIgnore = tryAwaitOr(async () => { });\nexport const causesException = (func) => {\n  try {\n    func();\n    return false;\n  } catch (e) {\n    return true;\n  }\n};\n\nexport const executesWithoutException = func => !causesException(func);\n\nexport const handleErrorWith = returnValInError => tryOr(constant(returnValInError));\n\nexport const handleErrorWithUndefined = handleErrorWith(undefined);\n\nexport const switchCase = (...cases) => (value) => {\n  const nextCase = () => head(cases)[0](value);\n  const nextResult = () => head(cases)[1](value);\n\n  if (isEmpty(cases)) return; // undefined\n  if (nextCase() === true) return nextResult();\n  return switchCase(...tail(cases))(value);\n};\n\nexport const isValue = val1 => val2 => (val1 === val2);\nexport const isOneOf = (...vals) => val => includes(val)(vals);\nexport const defaultCase = constant(true);\nexport const memberMatches = (member, match) => obj => match(obj[member]);\n\n\nexport const StartsWith = searchFor => searchIn => startsWith(searchIn, searchFor);\n\nexport const contains = val => array => (findIndex(array, v => v === val) > -1);\n\nexport const getHashCode = (s) => {\n  let hash = 0; let i; let char; let\n    l;\n  if (s.length == 0) return hash;\n  for (i = 0, l = s.length; i < l; i++) {\n    char = s.charCodeAt(i);\n    hash = ((hash << 5) - hash) + char;\n    hash |= 0; // Convert to 32bit integer\n  }\n\n  // converting to string, but dont want a \"-\" prefixed\n  if (hash < 0) { return `n${(hash * -1).toString()}`; }\n  return hash.toString();\n};\n\n// thanks to https://blog.grossman.io/how-to-write-async-await-without-try-catch-blocks-in-javascript/\nexport const awEx = async (promise) => {\n  try {\n    const result = await promise;\n    return [undefined, result];\n  } catch (error) {\n    return [error, undefined];\n  }\n};\n\nexport const isSafeInteger = n => isInteger(n)\n    && n <= Number.MAX_SAFE_INTEGER\n    && n >= 0 - Number.MAX_SAFE_INTEGER;\n\nexport const toDateOrNull = s => (isNull(s) ? null\n  : isDate(s) ? s : new Date(s));\nexport const toBoolOrNull = s => (isNull(s) ? null\n  : s === 'true' || s === true);\nexport const toNumberOrNull = s => (isNull(s) ? null\n  : toNumber(s));\n\nexport const isArrayOfString = opts => isArray(opts) && all(isString)(opts);\n\nexport const pushAll = (target, items) => {\n  for(let i of items) target.push(i);\n}\n\nexport const pause = async duration => new Promise(res => setTimeout(res, duration));\n\nexport const retry = async (fn, retries, delay, ...args) => {\n  try {\n    return await fn(...args);\n  } catch (err) {\n    if (retries > 1) {\n      return await pause(delay).then(async () => await retry(fn, (retries - 1), delay, ...args));\n    }\n    throw err;\n  }\n};\n\nexport { events } from './events';\nexport { apiWrapper, apiWrapperSync } from './apiWrapper';\nexport {\n  getLock, NO_LOCK, releaseLock,\n  extendLock, isNolock,\n} from './lock';\n\nexport default {\n  ifExists,\n  getOrDefault,\n  isDefined,\n  isNonNull,\n  isNotNaN,\n  allTrue,\n  isSomething,\n  mapIfSomethingOrDefault,\n  mapIfSomethingOrBlank,\n  configFolder,\n  fieldDefinitions,\n  isNothing,\n  not,\n  switchCase,\n  defaultCase,\n  StartsWith,\n  contains,\n  templateDefinitions,\n  handleErrorWith,\n  handleErrorWithUndefined,\n  tryOr,\n  tryOrIgnore,\n  tryAwaitOr,\n  tryAwaitOrIgnore,\n  dirIndex,\n  keySep,\n  $,\n  $$,\n  getDirFomKey,\n  getFileFromKey,\n  splitKey,\n  somethingOrDefault,\n  getIndexKeyFromFileKey,\n  joinKey,\n  somethingOrGetDefault,\n  appDefinitionFile,\n  isValue,\n  all,\n  isOneOf,\n  memberMatches,\n  defineError,\n  anyTrue,\n  isNonEmptyArray,\n  causesException,\n  executesWithoutException,\n  none,\n  getHashCode,\n  awEx,\n  apiWrapper,\n  events,\n  eventsList,\n  isNothingOrEmpty,\n  isSafeInteger,\n  toNumber,\n  toDate: toDateOrNull,\n  toBool: toBoolOrNull,\n  isArrayOfString,\n  getLock,\n  NO_LOCK,\n  isNolock,\n  insensitiveEquals,\n  pause,\n  retry,\n  pushAll\n};\n","import { filter, map } from 'lodash/fp';\nimport { $, isSomething } from './index';\n\nexport const stringNotEmpty = s => isSomething(s) && s.trim().length > 0;\n\nexport const makerule = (field, error, isValid) => ({ field, error, isValid });\n\nexport const validationError = (rule, item) => ({ ...rule, item });\n\nexport const applyRuleSet = ruleSet => itemToValidate => $(ruleSet, [\n  map(applyRule(itemToValidate)),\n  filter(isSomething),\n]);\n\nexport const applyRule = itemTovalidate => rule => (rule.isValid(itemTovalidate)\n  ? null\n  : validationError(rule, itemTovalidate));\n","import { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  isUndefined, keys, \n  cloneDeep, isFunction,\n} from 'lodash/fp';\nimport { defineError } from '../common';\n\nexport const filterEval = 'FILTER_EVALUATE';\nexport const filterCompile = 'FILTER_COMPILE';\nexport const mapEval = 'MAP_EVALUATE';\nexport const mapCompile = 'MAP_COMPILE';\nexport const removeUndeclaredFields = 'REMOVE_UNDECLARED_FIELDS';\nexport const addUnMappedFields = 'ADD_UNMAPPED_FIELDS';\nexport const addTheKey = 'ADD_KEY';\n\n\nconst getEvaluateResult = () => ({\n  isError: false,\n  passedFilter: true,\n  result: null,\n});\n\nexport const compileFilter = index => compileExpression(index.filter);\n\nexport const compileMap = index => compileCode(index.map);\n\nexport const passesFilter = (record, index) => {\n  const context = { record };\n  if (!index.filter) return true;\n\n  const compiledFilter = defineError(\n    () => compileFilter(index),\n    filterCompile,\n  );\n\n  return defineError(\n    () => compiledFilter(context),\n    filterEval,\n  );\n};\n\nexport const mapRecord = (record, index) => {\n  const recordClone = cloneDeep(record);\n  const context = { record: recordClone };\n\n  const map = index.map ? index.map : 'return {...record};';\n\n  const compiledMap = defineError(\n    () => compileCode(map),\n    mapCompile,\n  );\n\n  const mapped = defineError(\n    () => compiledMap(context),\n    mapEval,\n  );\n\n  const mappedKeys = keys(mapped);\n  for (let i = 0; i < mappedKeys.length; i++) {\n    const key = mappedKeys[i];\n    mapped[key] = isUndefined(mapped[key]) ? null : mapped[key];\n    if (isFunction(mapped[key])) {\n      delete mapped[key];\n    }\n  }\n\n  mapped.key = record.key;\n  mapped.sortKey = index.getSortKey\n    ? compileCode(index.getSortKey)(context)\n    : record.id;\n\n  return mapped;\n};\n\nexport const evaluate = record => (index) => {\n  const result = getEvaluateResult();\n\n  try {\n    result.passedFilter = passesFilter(record, index);\n  } catch (err) {\n    result.isError = true;\n    result.passedFilter = false;\n    result.result = err.message;\n  }\n\n  if (!result.passedFilter) return result;\n\n  try {\n    result.result = mapRecord(record, index);\n  } catch (err) {\n    result.isError = true;\n    result.result = err.message;\n  }\n\n  return result;\n};\n\nexport default evaluate;\n","import {\n  map, isEmpty, countBy, \n  flatten, includes, join, keys\n} from 'lodash/fp';\nimport {  } from 'lodash';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { compileFilter, compileMap } from '../indexing/evaluate';\nimport { isNonEmptyString, executesWithoutException, $ } from '../common';\nimport { isRecord } from './hierarchy';\n\nexport const indexTypes = { reference: 'reference', ancestor: 'ancestor' };\n\nexport const indexRuleSet = [\n  makerule('map', 'index has no map function',\n    index => isNonEmptyString(index.map)),\n  makerule('map', \"index's map function does not compile\",\n    index => !isNonEmptyString(index.map)\n                || executesWithoutException(() => compileMap(index))),\n  makerule('filter', \"index's filter function does not compile\",\n    index => !isNonEmptyString(index.filter)\n                || executesWithoutException(() => compileFilter(index))),\n  makerule('name', 'must declare a name for index',\n    index => isNonEmptyString(index.name)),\n  makerule('name', 'there is a duplicate named index on this node',\n    index => isEmpty(index.name)\n                || countBy('name')(index.parent().indexes)[index.name] === 1),\n  makerule('indexType', 'reference index may only exist on a record node',\n    index => isRecord(index.parent())\n                  || index.indexType !== indexTypes.reference),\n  makerule('indexType', `index type must be one of: ${join(', ')(keys(indexTypes))}`,\n    index => includes(index.indexType)(keys(indexTypes))),\n];\n\nexport const validateIndex = (index, allReferenceIndexesOnNode) => applyRuleSet(indexRuleSet(allReferenceIndexesOnNode))(index);\n\nexport const validateAllIndexes = node => $(node.indexes, [\n  map(i => validateIndex(i, node.indexes)),\n  flatten,\n]);\n","import {\n  find, constant, map, last,\n  first, split, intersection, take,\n  union, includes, filter, some,\n} from 'lodash/fp';\nimport {\n  $, switchCase, isNothing, isSomething,\n  defaultCase, splitKey, isNonEmptyString,\n  joinKey, getHashCode,\n} from '../common';\nimport { indexTypes } from './indexes';\n\nexport const getFlattenedHierarchy = (appHierarchy, useCached = true) => {\n  if (isSomething(appHierarchy.getFlattenedHierarchy) && useCached) { return appHierarchy.getFlattenedHierarchy(); }\n\n  const flattenHierarchy = (currentNode, flattened) => {\n    flattened.push(currentNode);\n    if ((!currentNode.children\n            || currentNode.children.length === 0)\n            && (!currentNode.indexes\n            || currentNode.indexes.length === 0)\n            && (!currentNode.aggregateGroups\n            || currentNode.aggregateGroups.length === 0)) {\n      return flattened;\n    }\n\n    const unionIfAny = l2 => l1 => union(l1)(!l2 ? [] : l2);\n\n    const children = $([], [\n      unionIfAny(currentNode.children),\n      unionIfAny(currentNode.indexes),\n      unionIfAny(currentNode.aggregateGroups),\n    ]);\n\n    for (const child of children) {\n      flattenHierarchy(child, flattened);\n    }\n    return flattened;\n  };\n\n  appHierarchy.getFlattenedHierarchy = () => flattenHierarchy(appHierarchy, []);\n  return appHierarchy.getFlattenedHierarchy();\n};\n\nexport const getLastPartInKey = key => last(splitKey(key));\n\nexport const getNodesInPath = appHierarchy => key => $(appHierarchy, [\n  getFlattenedHierarchy,\n  filter(n => new RegExp(`${n.pathRegx()}`).test(key)),\n]);\n\nexport const getExactNodeForKey = appHierarchy => key => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => new RegExp(`${n.pathRegx()}$`).test(key)),\n]);\n\nexport const getNodeForCollectionPath = appHierarchy => collectionKey => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => (isCollectionRecord(n)\n                   && new RegExp(`${n.collectionPathRegx()}$`).test(collectionKey))),\n]);\n\nexport const hasMatchingAncestor = ancestorPredicate => decendantNode => switchCase(\n\n  [node => isNothing(node.parent()),\n    constant(false)],\n\n  [node => ancestorPredicate(node.parent()),\n    constant(true)],\n\n  [defaultCase,\n    node => hasMatchingAncestor(ancestorPredicate)(node.parent())],\n\n)(decendantNode);\n\nexport const getNode = (appHierarchy, nodeKey) => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => n.nodeKey() === nodeKey\n                  || (isCollectionRecord(n)\n                      && n.collectionNodeKey() === nodeKey)),\n]);\n\nexport const getCollectionNode = (appHierarchy, nodeKey) => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => (isCollectionRecord(n)\n                    && n.collectionNodeKey() === nodeKey)),\n]);\n\nexport const getNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => {\n  const nodeByKey = getExactNodeForKey(appHierarchy)(keyOrNodeKey);\n  return isNothing(nodeByKey)\n    ? getNode(appHierarchy, keyOrNodeKey)\n    : nodeByKey;\n};\n\nexport const getCollectionNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => {\n  const nodeByKey = getNodeForCollectionPath(appHierarchy)(keyOrNodeKey);\n  return isNothing(nodeByKey)\n    ? getCollectionNode(appHierarchy, keyOrNodeKey)\n    : nodeByKey;\n};\n\nexport const isNode = (appHierarchy, key) => isSomething(getExactNodeForKey(appHierarchy)(key));\n\nexport const getActualKeyOfParent = (parentNodeKey, actualChildKey) => \n  $(actualChildKey, [\n    splitKey,\n    take(splitKey(parentNodeKey).length),\n    ks => joinKey(...ks),\n  ]);\n\nexport const getParentKey = (key) => {\n  return $(key, [\n    splitKey,\n    take(splitKey(key).length - 1),\n    joinKey,\n  ]);\n};\n\nexport const isKeyAncestorOf = ancestorKey => decendantNode => hasMatchingAncestor(p => p.nodeKey() === ancestorKey)(decendantNode);\n\nexport const hasNoMatchingAncestors = parentPredicate => node => !hasMatchingAncestor(parentPredicate)(node);\n\nexport const findField = (recordNode, fieldName) => find(f => f.name == fieldName)(recordNode.fields);\n\nexport const isAncestor = decendant => ancestor => isKeyAncestorOf(ancestor.nodeKey())(decendant);\n\nexport const isDecendant = ancestor => decendant => isAncestor(decendant)(ancestor);\n\nexport const getRecordNodeId = recordKey => $(recordKey, [\n  splitKey,\n  last,\n  getRecordNodeIdFromId,\n]);\n\nexport const getRecordNodeIdFromId = recordId => $(recordId, [split('-'), first, parseInt]);\n\nexport const getRecordNodeById = (hierarchy, recordId) => $(hierarchy, [\n  getFlattenedHierarchy,\n  find(n => isRecord(n)\n                    && n.nodeId === getRecordNodeIdFromId(recordId)),\n]);\n\nexport const recordNodeIdIsAllowed = indexNode => nodeId => indexNode.allowedRecordNodeIds.length === 0\n    || includes(nodeId)(indexNode.allowedRecordNodeIds);\n\nexport const recordNodeIsAllowed = indexNode => recordNode => recordNodeIdIsAllowed(indexNode)(recordNode.nodeId);\n\nexport const getAllowedRecordNodesForIndex = (appHierarchy, indexNode) => {\n  const recordNodes = $(appHierarchy, [\n    getFlattenedHierarchy,\n    filter(isRecord),\n  ]);\n\n  if (isGlobalIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(recordNodeIsAllowed(indexNode)),\n    ]);\n  }\n\n  if (isAncestorIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(isDecendant(indexNode.parent())),\n      filter(recordNodeIsAllowed(indexNode)),\n    ]);\n  }\n\n  if (isReferenceIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(n => some(fieldReversesReferenceToIndex(indexNode))(n.fields)),\n    ]);\n  }\n};\n\nexport const getNodeFromNodeKeyHash = hierarchy => hash => $(hierarchy, [\n  getFlattenedHierarchy,\n  find(n => getHashCode(n.nodeKey()) === hash),\n]);\n\nexport const isRecord = node => isSomething(node) && node.type === 'record';\nexport const isSingleRecord = node => isRecord(node) && node.isSingle;\nexport const isCollectionRecord = node => isRecord(node) && !node.isSingle;\nexport const isIndex = node => isSomething(node) && node.type === 'index';\nexport const isaggregateGroup = node => isSomething(node) && node.type === 'aggregateGroup';\nexport const isShardedIndex = node => isIndex(node) && isNonEmptyString(node.getShardName);\nexport const isRoot = node => isSomething(node) && node.isRoot();\nexport const isDecendantOfARecord = hasMatchingAncestor(isRecord);\nexport const isGlobalIndex = node => isIndex(node) && isRoot(node.parent());\nexport const isReferenceIndex = node => isIndex(node) && node.indexType === indexTypes.reference;\nexport const isAncestorIndex = node => isIndex(node) && node.indexType === indexTypes.ancestor;\n\nexport const fieldReversesReferenceToNode = node => field => field.type === 'reference'\n    && intersection(field.typeOptions.reverseIndexNodeKeys)(map(i => i.nodeKey())(node.indexes))\n      .length > 0;\n\nexport const fieldReversesReferenceToIndex = indexNode => field => field.type === 'reference'\n    && intersection(field.typeOptions.reverseIndexNodeKeys)([indexNode.nodeKey()])\n      .length > 0;\n\nexport default {\n  getLastPartInKey,\n  getNodesInPath,\n  getExactNodeForKey,\n  hasMatchingAncestor,\n  getNode,\n  getNodeByKeyOrNodeKey,\n  isNode,\n  getActualKeyOfParent,\n  getParentKey,\n  isKeyAncestorOf,\n  hasNoMatchingAncestors,\n  findField,\n  isAncestor,\n  isDecendant,\n  getRecordNodeId,\n  getRecordNodeIdFromId,\n  getRecordNodeById,\n  recordNodeIdIsAllowed,\n  recordNodeIsAllowed,\n  getAllowedRecordNodesForIndex,\n  getNodeFromNodeKeyHash,\n  isRecord,\n  isCollectionRecord,\n  isIndex,\n  isaggregateGroup,\n  isShardedIndex,\n  isRoot,\n  isDecendantOfARecord,\n  isGlobalIndex,\n  isReferenceIndex,\n  isAncestorIndex,\n  fieldReversesReferenceToNode,\n  fieldReversesReferenceToIndex,\n  getFlattenedHierarchy,\n};\n","import { merge } from 'lodash';\nimport {\n  constant, isUndefined, has,\n  mapValues, cloneDeep,\n} from 'lodash/fp';\nimport { isNotEmpty } from '../common';\n\nexport const getSafeFieldParser = (tryParse, defaultValueFunctions) => (field, record) => {\n  if (has(field.name)(record)) {\n    return getSafeValueParser(tryParse, defaultValueFunctions)(record[field.name]);\n  }\n  return defaultValueFunctions[field.getUndefinedValue]();\n};\n\nexport const getSafeValueParser = (tryParse, defaultValueFunctions) => (value) => {\n  const parsed = tryParse(value);\n  if (parsed.success) {\n    return parsed.value;\n  }\n  return defaultValueFunctions.default();\n};\n\nexport const getNewValue = (tryParse, defaultValueFunctions) => (field) => {\n  const getInitialValue = isUndefined(field) || isUndefined(field.getInitialValue)\n    ? 'default'\n    : field.getInitialValue;\n\n  return has(getInitialValue)(defaultValueFunctions)\n    ? defaultValueFunctions[getInitialValue]()\n    : getSafeValueParser(tryParse, defaultValueFunctions)(getInitialValue);\n};\n\nexport const typeFunctions = specificFunctions => merge({\n  value: constant,\n  null: constant(null),\n}, specificFunctions);\n\nexport const validateTypeConstraints = validationRules => async (field, record, context) => {\n  const fieldValue = record[field.name];\n  const validateRule = async r => (!await r.isValid(fieldValue, field.typeOptions, context)\n    ? r.getMessage(fieldValue, field.typeOptions)\n    : '');\n\n  const errors = [];\n  for (const r of validationRules) {\n    const err = await validateRule(r);\n    if (isNotEmpty(err)) errors.push(err);\n  }\n\n  return errors;\n};\n\nconst getDefaultOptions = mapValues(v => v.defaultValue);\n\nexport const makerule = (isValid, getMessage) => ({ isValid, getMessage });\nexport const parsedFailed = val => ({ success: false, value: val });\nexport const parsedSuccess = val => ({ success: true, value: val });\nexport const getDefaultExport = (name, tryParse, functions, options, validationRules, sampleValue, stringify) => ({\n  getNew: getNewValue(tryParse, functions),\n  safeParseField: getSafeFieldParser(tryParse, functions),\n  safeParseValue: getSafeValueParser(tryParse, functions),\n  tryParse,\n  name,\n  getDefaultOptions: () => getDefaultOptions(cloneDeep(options)),\n  optionDefinitions: options,\n  validateTypeConstraints: validateTypeConstraints(validationRules),\n  sampleValue,\n  stringify: val => (val === null || val === undefined\n    ? '' : stringify(val)),\n  getDefaultValue: functions.default,\n});\n","import {\n  constant, isString,\n  isNull, includes, isBoolean,\n} from 'lodash/fp';\nimport {\n  typeFunctions,\n  makerule, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toBoolOrNull, toNumberOrNull,\n  isSafeInteger, isArrayOfString,\n} from '../common';\n\nconst stringFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst stringTryParse = switchCase(\n  [isString, parsedSuccess],\n  [isNull, parsedSuccess],\n  [defaultCase, v => parsedSuccess(v.toString())],\n);\n\nconst options = {\n  maxLength: {\n    defaultValue: null,\n    isValid: n => n === null || isSafeInteger(n) && n > 0,\n    requirementDescription: 'max length must be null (no limit) or a greater than zero integer',\n    parse: toNumberOrNull,\n  },\n  values: {\n    defaultValue: null,\n    isValid: v => v === null || (isArrayOfString(v) && v.length > 0 && v.length < 10000),\n    requirementDescription: \"'values' must be null (no values) or an arry of at least one string\",\n    parse: s => s,\n  },\n  allowDeclaredValuesOnly: {\n    defaultValue: false,\n    isValid: isBoolean,\n    requirementDescription: 'allowDeclaredValuesOnly must be true or false',\n    parse: toBoolOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.maxLength === null || val.length <= opts.maxLength,\n    (val, opts) => `value exceeds maximum length of ${opts.maxLength}`),\n  makerule(async (val, opts) => val === null\n                           || opts.allowDeclaredValuesOnly === false\n                           || includes(val)(opts.values),\n  (val) => `\"${val}\" does not exist in the list of allowed values`),\n];\n\nexport default getDefaultExport(\n  'string',\n  stringTryParse,\n  stringFunctions,\n  options,\n  typeConstraints,\n  'abcde',\n  str => str,\n);\n","import { constant, isBoolean, isNull } from 'lodash/fp';\nimport {\n  typeFunctions,\n  makerule, parsedFailed, parsedSuccess,\n  getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, isOneOf, toBoolOrNull,\n} from '../common';\n\nconst boolFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst boolTryParse = switchCase(\n  [isBoolean, parsedSuccess],\n  [isNull, parsedSuccess],\n  [isOneOf('true', '1', 'yes', 'on'), () => parsedSuccess(true)],\n  [isOneOf('false', '0', 'no', 'off'), () => parsedSuccess(false)],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  allowNulls: {\n    defaultValue: true,\n    isValid: isBoolean,\n    requirementDescription: 'must be a true or false',\n    parse: toBoolOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => opts.allowNulls === true || val !== null,\n    () => 'field cannot be null'),\n];\n\nexport default getDefaultExport(\n  'bool', boolTryParse, boolFunctions,\n  options, typeConstraints, true, JSON.stringify,\n);\n","import {\n  constant, isNumber, isString, isNull,\n} from 'lodash/fp';\nimport {\n  makerule, typeFunctions,\n  parsedFailed, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toNumberOrNull,\n  isSafeInteger,\n} from '../common';\n\nconst numberFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst parseStringtoNumberOrNull = (s) => {\n  const num = Number(s);\n  return isNaN(num) ? parsedFailed(s) : parsedSuccess(num);\n};\n\nconst numberTryParse = switchCase(\n  [isNumber, parsedSuccess],\n  [isString, parseStringtoNumberOrNull],\n  [isNull, parsedSuccess],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  maxValue: {\n    defaultValue: Number.MAX_SAFE_INTEGER,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a valid integer',\n    parse: toNumberOrNull,\n  },\n  minValue: {\n    defaultValue: 0 - Number.MAX_SAFE_INTEGER,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a valid integer',\n    parse: toNumberOrNull,\n  },\n  decimalPlaces: {\n    defaultValue: 0,\n    isValid: n => isSafeInteger(n) && n >= 0,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n};\n\nconst getDecimalPlaces = (val) => {\n  const splitDecimal = val.toString().split('.');\n  if (splitDecimal.length === 1) return 0;\n  return splitDecimal[1].length;\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue,\n    (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`),\n  makerule(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue,\n    (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`),\n  makerule(async (val, opts) => val === null || opts.decimalPlaces >= getDecimalPlaces(val),\n    (val, opts) => `value (${val.toString()}) must have ${opts.decimalPlaces} decimal places or less`),\n];\n\nexport default getDefaultExport(\n  'number',\n  numberTryParse,\n  numberFunctions,\n  options,\n  typeConstraints,\n  1,\n  num => num.toString(),\n);\n","import {\n  constant, isDate, isString, isNull\n} from 'lodash/fp';\nimport {\n  makerule, typeFunctions,\n  parsedFailed, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toDateOrNull,\n} from '../common';\n\nconst dateFunctions = typeFunctions({\n  default: constant(null),\n  now: () => new Date(),\n});\n\nconst isValidDate = d => d instanceof Date && !isNaN(d);\n\nconst parseStringToDate = s => switchCase(\n  [isValidDate, parsedSuccess],\n  [defaultCase, parsedFailed],\n)(new Date(s));\n\n\nconst dateTryParse = switchCase(\n  [isDate, parsedSuccess],\n  [isString, parseStringToDate],\n  [isNull, parsedSuccess],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  maxValue: {\n    defaultValue: new Date(32503680000000),\n    isValid: isDate,\n    requirementDescription: 'must be a valid date',\n    parse: toDateOrNull,\n  },\n  minValue: {\n    defaultValue: new Date(-8520336000000),\n    isValid: isDate,\n    requirementDescription: 'must be a valid date',\n    parse: toDateOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue,\n    (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`),\n  makerule(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue,\n    (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`),\n];\n\nexport default getDefaultExport(\n  'datetime',\n  dateTryParse,\n  dateFunctions,\n  options,\n  typeConstraints,\n  new Date(1984, 4, 1),\n  date => JSON.stringify(date).replace(new RegExp('\"', 'g'), ''),\n);\n","import { \n  map,  constant, isArray \n} from 'lodash/fp';\nimport {\n  typeFunctions, makerule,\n  parsedFailed, getDefaultExport, parsedSuccess,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toNumberOrNull,\n  $$, isSafeInteger,\n} from '../common';\n\nconst arrayFunctions = () => typeFunctions({\n  default: constant([]),\n});\n\nconst mapToParsedArrary = type => $$(\n  map(i => type.safeParseValue(i)),\n  parsedSuccess,\n);\n\nconst arrayTryParse = type => switchCase(\n  [isArray, mapToParsedArrary(type)],\n  [defaultCase, parsedFailed],\n);\n\nconst typeName = type => `array<${type}>`;\n\n\nconst options = {\n  maxLength: {\n    defaultValue: 10000,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n  minLength: {\n    defaultValue: 0,\n    isValid: n => isSafeInteger(n) && n >= 0,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || val.length >= opts.minLength,\n    (val, opts) => `must choose ${opts.minLength} or more options`),\n  makerule(async (val, opts) => val === null || val.length <= opts.maxLength,\n    (val, opts) => `cannot choose more than ${opts.maxLength} options`),\n];\n\nexport default type => getDefaultExport(\n  typeName(type.name),\n  arrayTryParse(type),\n  arrayFunctions(type),\n  options,\n  typeConstraints,\n  [type.sampleValue],\n  JSON.stringify,\n);\n","import {\n  isString, isObjectLike,\n  isNull, has, isEmpty,\n} from 'lodash/fp';\nimport {\n  typeFunctions, makerule,\n  parsedSuccess, getDefaultExport,\n  parsedFailed,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase,\n  isNonEmptyString, isArrayOfString,\n} from '../common';\n\nconst referenceNothing = () => ({ key: '' });\n\nconst referenceFunctions = typeFunctions({\n  default: referenceNothing,\n});\n\nconst hasStringValue = (ob, path) => has(path)(ob)\n    && isString(ob[path]);\n\nconst isObjectWithKey = v => isObjectLike(v)\n    && hasStringValue(v, 'key');\n\nconst tryParseFromString = s => {\n\n  try {\n    const asObj = JSON.parse(s);\n    if(isObjectWithKey) {\n      return parsedSuccess(asObj);\n    }\n  }\n  catch(_) {\n    // EMPTY\n  }\n\n  return parsedFailed(s);\n}\n\nconst referenceTryParse = v => switchCase(\n  [isObjectWithKey, parsedSuccess],\n  [isString, tryParseFromString],\n  [isNull, () => parsedSuccess(referenceNothing())],\n  [defaultCase, parsedFailed],\n)(v);\n\nconst options = {\n  indexNodeKey: {\n    defaultValue: null,\n    isValid: isNonEmptyString,\n    requirementDescription: 'must be a non-empty string',\n    parse: s => s,\n  },\n  displayValue: {\n    defaultValue: '',\n    isValid: isNonEmptyString,\n    requirementDescription: 'must be a non-empty string',\n    parse: s => s,\n  },\n  reverseIndexNodeKeys: {\n    defaultValue: null,\n    isValid: v => isArrayOfString(v) && v.length > 0,\n    requirementDescription: 'must be a non-empty array of strings',\n    parse: s => s,\n  },\n};\n\nconst isEmptyString = s => isString(s) && isEmpty(s);\n\nconst ensureReferenceExists = async (val, opts, context) => isEmptyString(val.key)\n    || await context.referenceExists(opts, val.key);\n\nconst typeConstraints = [\n  makerule(\n    ensureReferenceExists,\n    (val, opts) => `\"${val[opts.displayValue]}\" does not exist in options list (key: ${val.key})`,\n  ),\n];\n\nexport default getDefaultExport(\n  'reference',\n  referenceTryParse,\n  referenceFunctions,\n  options,\n  typeConstraints,\n  { key: 'key', value: 'value' },\n  JSON.stringify,\n);\n","import {\n  last, has, isString, intersection,\n  isNull, isNumber,\n} from 'lodash/fp';\nimport {\n  typeFunctions, parsedFailed,\n  parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, none,\n  $, splitKey,\n} from '../common';\n\nconst illegalCharacters = '*?\\\\/:<>|\\0\\b\\f\\v';\n\nexport const isLegalFilename = (filePath) => {\n  const fn = fileName(filePath);\n  return fn.length <= 255\n    && intersection(fn.split(''))(illegalCharacters.split('')).length === 0\n    && none(f => f === '..')(splitKey(filePath));\n};\n\nconst fileNothing = () => ({ relativePath: '', size: 0 });\n\nconst fileFunctions = typeFunctions({\n  default: fileNothing,\n});\n\nconst fileTryParse = v => switchCase(\n  [isValidFile, parsedSuccess],\n  [isNull, () => parsedSuccess(fileNothing())],\n  [defaultCase, parsedFailed],\n)(v);\n\nconst fileName = filePath => $(filePath, [\n  splitKey,\n  last,\n]);\n\nconst isValidFile = f => !isNull(f)\n    && has('relativePath')(f) && has('size')(f)\n    && isNumber(f.size)\n    && isString(f.relativePath)\n    && isLegalFilename(f.relativePath);\n\nconst options = {};\n\nconst typeConstraints = [];\n\nexport default getDefaultExport(\n  'file',\n  fileTryParse,\n  fileFunctions,\n  options,\n  typeConstraints,\n  { relativePath: 'some_file.jpg', size: 1000 },\n  JSON.stringify,\n);\n","import {\n  assign, merge, \n} from 'lodash';\nimport {\n  map, isString, isNumber,\n  isBoolean, isDate, keys,\n  isObject, isArray, has\n} from 'lodash/fp';\nimport { $ } from '../common';\nimport { parsedSuccess } from './typeHelpers';\nimport string from './string';\nimport bool from './bool';\nimport number from './number';\nimport datetime from './datetime';\nimport array from './array';\nimport reference from './reference';\nimport file from './file';\nimport { BadRequestError } from '../common/errors';\n\nconst allTypes = () => {\n  const basicTypes = {\n    string, number, datetime, bool, reference, file,\n  };\n\n  const arrays = $(basicTypes, [\n    keys,\n    map((k) => {\n      const kvType = {};\n      const concreteArray = array(basicTypes[k]);\n      kvType[concreteArray.name] = concreteArray;\n      return kvType;\n    }),\n    types => assign({}, ...types),\n  ]);\n\n  return merge({}, basicTypes, arrays);\n};\n\n\nexport const all = allTypes();\n\nexport const getType = (typeName) => {\n  if (!has(typeName)(all)) throw new BadRequestError(`Do not recognise type ${typeName}`);\n  return all[typeName];\n};\n\nexport const getSampleFieldValue = field => getType(field.type).sampleValue;\n\nexport const getNewFieldValue = field => getType(field.type).getNew(field);\n\nexport const safeParseField = (field, record) => getType(field.type).safeParseField(field, record);\n\nexport const validateFieldParse = (field, record) => (has(field.name)(record)\n  ? getType(field.type).tryParse(record[field.name])\n  : parsedSuccess(undefined)); // fields may be undefined by default\n\nexport const getDefaultOptions = type => getType(type).getDefaultOptions();\n\nexport const validateTypeConstraints = async (field, record, context) => await getType(field.type).validateTypeConstraints(field, record, context);\n\nexport const detectType = (value) => {\n  if (isString(value)) return string;\n  if (isBoolean(value)) return bool;\n  if (isNumber(value)) return number;\n  if (isDate(value)) return datetime;\n  if (isArray(value)) return array(detectType(value[0]));\n  if (isObject(value)\n       && has('key')(value)\n       && has('value')(value)) return reference;\n  if (isObject(value)\n        && has('relativePath')(value)\n        && has('size')(value)) return file;\n\n  throw new BadRequestError(`cannot determine type: ${JSON.stringify(value)}`);\n};\n","import { clone, find, split } from 'lodash/fp';\nimport { joinKey, $ } from '../common';\n// 5 minutes\nexport const tempCodeExpiryLength = 5 * 60 * 1000;\n\nexport const AUTH_FOLDER = '/.auth';\nexport const USERS_LIST_FILE = joinKey(AUTH_FOLDER, 'users.json');\nexport const userAuthFile = username => joinKey(AUTH_FOLDER, `auth_${username}.json`);\nexport const USERS_LOCK_FILE = joinKey(AUTH_FOLDER, 'users_lock');\nexport const ACCESS_LEVELS_FILE = joinKey(AUTH_FOLDER, 'access_levels.json');\nexport const ACCESS_LEVELS_LOCK_FILE = joinKey(AUTH_FOLDER, 'access_levels_lock');\n\nexport const permissionTypes = {\n  CREATE_RECORD: 'create record',\n  UPDATE_RECORD: 'update record',\n  READ_RECORD: 'read record',\n  DELETE_RECORD: 'delete record',\n  READ_INDEX: 'read index',\n  MANAGE_INDEX: 'manage index',\n  MANAGE_COLLECTION: 'manage collection',\n  WRITE_TEMPLATES: 'write templates',\n  CREATE_USER: 'create user',\n  SET_PASSWORD: 'set password',\n  CREATE_TEMPORARY_ACCESS: 'create temporary access',\n  ENABLE_DISABLE_USER: 'enable or disable user',\n  WRITE_ACCESS_LEVELS: 'write access levels',\n  LIST_USERS: 'list users',\n  LIST_ACCESS_LEVELS: 'list access levels',\n  EXECUTE_ACTION: 'execute action',\n  SET_USER_ACCESS_LEVELS: 'set user access levels',\n};\n\nexport const getUserByName = (users, name) => $(users, [\n  find(u => u.name.toLowerCase() === name.toLowerCase()),\n]);\n\nexport const stripUserOfSensitiveStuff = (user) => {\n  const stripped = clone(user);\n  delete stripped.tempCode;\n  return stripped;\n};\n\nexport const parseTemporaryCode = fullCode => $(fullCode, [\n  split(':'),\n  parts => ({\n    id: parts[1],\n    code: parts[2],\n  }),\n]);\n","import { values, includes, some } from 'lodash/fp';\nimport { permissionTypes } from './authCommon';\nimport {\n  $, isNothing, apiWrapperSync, events,\n} from '../common';\nimport { getNodeByKeyOrNodeKey, isNode } from '../templateApi/hierarchy';\nimport { alwaysAuthorized } from './permissions';\n\nexport const isAuthorized = app => (permissionType, resourceKey) => apiWrapperSync(\n  app,\n  events.authApi.isAuthorized,\n  alwaysAuthorized,\n  { resourceKey, permissionType },\n  _isAuthorized, app, permissionType, resourceKey,\n);\n\nexport const _isAuthorized = (app, permissionType, resourceKey) => {\n  if (!app.user) {\n    return false;\n  }\n\n  const validType = $(permissionTypes, [\n    values,\n    includes(permissionType),\n  ]);\n\n  if (!validType) {\n    return false;\n  }\n\n  const permMatchesResource = (userperm) => {\n    const nodeKey = isNothing(resourceKey)\n      ? null\n      : isNode(app.hierarchy, resourceKey)\n        ? getNodeByKeyOrNodeKey(\n          app.hierarchy, resourceKey,\n        ).nodeKey()\n        : resourceKey;\n\n    return (userperm.type === permissionType)\n        && (\n          isNothing(resourceKey)\n            || nodeKey === userperm.nodeKey\n        );\n  };\n\n  return $(app.user.permissions, [\n    some(permMatchesResource),\n  ]);\n};\n","import { permissionTypes } from './authCommon';\nimport { isAuthorized } from './isAuthorized';\n\nexport const temporaryAccessPermissions = () => ([{ type: permissionTypes.SET_PASSWORD }]);\n\nconst nodePermission = type => ({\n  add: (nodeKey, accessLevel) => accessLevel.permissions.push({ type, nodeKey }),\n  isAuthorized: resourceKey => app => isAuthorized(app)(type, resourceKey),\n  isNode: true,\n  get: nodeKey => ({ type, nodeKey }),\n});\n\nconst staticPermission = type => ({\n  add: accessLevel => accessLevel.permissions.push({ type }),\n  isAuthorized: app => isAuthorized(app)(type),\n  isNode: false,\n  get: () => ({ type }),\n});\n\nconst createRecord = nodePermission(permissionTypes.CREATE_RECORD);\n\nconst updateRecord = nodePermission(permissionTypes.UPDATE_RECORD);\n\nconst deleteRecord = nodePermission(permissionTypes.DELETE_RECORD);\n\nconst readRecord = nodePermission(permissionTypes.READ_RECORD);\n\nconst writeTemplates = staticPermission(permissionTypes.WRITE_TEMPLATES);\n\nconst createUser = staticPermission(permissionTypes.CREATE_USER);\n\nconst setPassword = staticPermission(permissionTypes.SET_PASSWORD);\n\nconst readIndex = nodePermission(permissionTypes.READ_INDEX);\n\nconst manageIndex = staticPermission(permissionTypes.MANAGE_INDEX);\n\nconst manageCollection = staticPermission(permissionTypes.MANAGE_COLLECTION);\n\nconst createTemporaryAccess = staticPermission(permissionTypes.CREATE_TEMPORARY_ACCESS);\n\nconst enableDisableUser = staticPermission(permissionTypes.ENABLE_DISABLE_USER);\n\nconst writeAccessLevels = staticPermission(permissionTypes.WRITE_ACCESS_LEVELS);\n\nconst listUsers = staticPermission(permissionTypes.LIST_USERS);\n\nconst listAccessLevels = staticPermission(permissionTypes.LIST_ACCESS_LEVELS);\n\nconst setUserAccessLevels = staticPermission(permissionTypes.SET_USER_ACCESS_LEVELS);\n\nconst executeAction = nodePermission(permissionTypes.EXECUTE_ACTION);\n\nexport const alwaysAuthorized = () => true;\n\nexport const permission = {\n  createRecord,\n  updateRecord,\n  deleteRecord,\n  readRecord,\n  writeTemplates,\n  createUser,\n  setPassword,\n  readIndex,\n  createTemporaryAccess,\n  enableDisableUser,\n  writeAccessLevels,\n  listUsers,\n  listAccessLevels,\n  manageIndex,\n  manageCollection,\n  executeAction,\n  setUserAccessLevels,\n};\n","import {\n  keyBy, mapValues,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { \n  getNodeForCollectionPath, isSingleRecord \n} from '../templateApi/hierarchy';\nimport { getNewFieldValue } from '../types';\nimport {\n  $, joinKey, safeKey, apiWrapperSync, events,\n} from '../common';\nimport { permission } from '../authApi/permissions';\n\nexport const getNew = app => (collectionKey, recordTypeName) => {\n  const recordNode = getRecordNode(app, collectionKey, recordTypeName);\n  collectionKey=safeKey(collectionKey);\n  return apiWrapperSync(\n    app,\n    events.recordApi.getNew,\n    permission.createRecord.isAuthorized(recordNode.nodeKey()),\n    { collectionKey, recordTypeName },\n    _getNew, recordNode, collectionKey,\n  );\n};\n\nexport const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey);\n\nconst getRecordNode = (app, collectionKey) => {\n  collectionKey = safeKey(collectionKey);\n  return getNodeForCollectionPath(app.hierarchy)(collectionKey);\n};\n\nexport const getNewChild = app => (recordKey, collectionName, recordTypeName) => \n  getNew(app)(joinKey(recordKey, collectionName), recordTypeName);\n\nexport const constructRecord = (recordNode, getFieldValue, collectionKey) => {\n  const record = $(recordNode.fields, [\n    keyBy('name'),\n    mapValues(getFieldValue),\n  ]);\n\n  record.id = `${recordNode.nodeId}-${generate()}`;\n  record.key = isSingleRecord(recordNode)\n               ? joinKey(collectionKey, recordNode.name)\n               : joinKey(collectionKey, record.id);\n  record.isNew = true;\n  record.type = recordNode.name;\n  return record;\n};\n","import {\n  flatten, orderBy,\n  filter, isUndefined\n} from 'lodash/fp';\nimport hierarchy, {\n  getFlattenedHierarchy,\n  getCollectionNodeByKeyOrNodeKey,\n  isCollectionRecord, isAncestor,\n} from '../templateApi/hierarchy';\nimport { joinKey, safeKey, $ } from '../common';\nimport { getCollectionDir } from \"../recordApi/recordInfo\";\n\nexport const RECORDS_PER_FOLDER = 1000;\nexport const allIdChars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_-';\n\n// this should never be changed - ever \n// - existing databases depend on the order of chars this string\n\n/**\n * folderStructureArray should return an array like\n * - [1] = all records fit into one folder\n * - [2] = all records fite into 2 folders\n * - [64, 3] = all records fit into 64 * 3 folders\n * - [64, 64, 10] = all records fit into 64 * 64 * 10 folder\n * (there are 64 possible chars in allIsChars) \n*/\nexport const folderStructureArray = (recordNode) => {\n\n  const totalFolders = Math.ceil(recordNode.estimatedRecordCount / 1000);\n  const folderArray = [];\n  let levelCount = 1;\n  while(64**levelCount < totalFolders) {\n    levelCount += 1;\n    folderArray.push(64);\n  }\n\n  const parentFactor = (64**folderArray.length);\n  if(parentFactor < totalFolders) {\n    folderArray.push(\n      Math.ceil(totalFolders / parentFactor)\n    );\n  }  \n\n  return folderArray;\n\n  /*\n  const maxRecords = currentFolderPosition === 0 \n                     ? RECORDS_PER_FOLDER\n                     : currentFolderPosition * 64 * RECORDS_PER_FOLDER;\n\n  if(maxRecords < recordNode.estimatedRecordCount) {\n    return folderStructureArray(\n            recordNode,\n            [...currentArray, 64], \n            currentFolderPosition + 1);\n  } else {\n    const childFolderCount = Math.ceil(recordNode.estimatedRecordCount / maxRecords );\n    return [...currentArray, childFolderCount]\n  }*/\n}\n\n\nexport const getAllIdsIterator = app => async (collection_Key_or_NodeKey) => {\n  collection_Key_or_NodeKey = safeKey(collection_Key_or_NodeKey);\n  const recordNode = getCollectionNodeByKeyOrNodeKey(\n    app.hierarchy,\n    collection_Key_or_NodeKey,\n  );\n\n  const getAllIdsIteratorForCollectionKey = async (recordNode, collectionKey) => {\n    \n    const folderStructure = folderStructureArray(recordNode)\n\n    let currentFolderContents = [];\n    let currentPosition = [];\n\n    const collectionDir = getCollectionDir(app.hierarchy, collectionKey);\n    const basePath = joinKey(\n      collectionDir, recordNode.nodeId.toString());\n  \n\n    \n    // \"folderStructure\" determines the top, sharding folders\n    // we need to add one, for the collection root folder, which\n    // always  exists \n    const levels = folderStructure.length + 1;\n    const topLevel = levels -1;\n\n   \n    /* populate initial directory structure in form:\n    [\n      {path: \"/a\", contents: [\"b\", \"c\", \"d\"]}, \n      {path: \"/a/b\", contents: [\"e\",\"f\",\"g\"]},\n      {path: \"/a/b/e\", contents: [\"1-abcd\",\"2-cdef\",\"3-efgh\"]}, \n    ]\n    // stores contents on each parent level\n    // top level has ID folders \n    */\n    const firstFolder = async () => {\n\n      let folderLevel = 0;\n\n      const lastPathHasContent = () => \n        folderLevel === 0 \n        || currentFolderContents[folderLevel - 1].contents.length > 0;\n\n\n      while (folderLevel <= topLevel && lastPathHasContent()) {\n\n        let thisPath = basePath;\n        for(let lev = 0; lev < currentPosition.length; lev++) {\n          thisPath = joinKey(\n            thisPath, currentFolderContents[lev].contents[0]);\n        }\n\n        const contentsThisLevel = \n          await app.datastore.getFolderContents(thisPath);\n        currentFolderContents.push({\n            contents:contentsThisLevel, \n            path: thisPath\n        });   \n\n        // should start as something like [0,0]\n        if(folderLevel < topLevel)\n          currentPosition.push(0); \n\n        folderLevel+=1;\n      }\n\n      return (currentPosition.length === levels - 1);\n    }  \n\n    const isOnLastFolder = level => {\n      \n      const result =  currentPosition[level] === currentFolderContents[level].contents.length - 1;\n      return result;\n    }\n    \n    const getNextFolder = async (lev=undefined) => {\n      lev = isUndefined(lev) ? topLevel : lev;\n      const parentLev = lev - 1;\n\n      if(parentLev < 0) return false;\n      \n      if(isOnLastFolder(parentLev)) { \n        return await getNextFolder(parentLev);\n      }\n\n      const newPosition = currentPosition[parentLev] + 1;\n      currentPosition[parentLev] = newPosition;\n      \n      const nextFolder = joinKey(\n        currentFolderContents[parentLev].path,\n        currentFolderContents[parentLev].contents[newPosition]);\n      currentFolderContents[lev].contents = await app.datastore.getFolderContents(\n        nextFolder\n      );\n      currentFolderContents[lev].path = nextFolder;\n\n      if(lev !== topLevel) {\n      \n        // we just advanced a parent folder, so now need to\n        // do the same to the next levels\n        let loopLevel = lev + 1;\n        while(loopLevel <= topLevel) {\n          const loopParentLevel = loopLevel-1;\n          \n          currentPosition[loopParentLevel] = 0;\n          const nextLoopFolder = joinKey(\n            currentFolderContents[loopParentLevel].path,\n            currentFolderContents[loopParentLevel].contents[0]);\n          currentFolderContents[loopLevel].contents = await app.datastore.getFolderContents(\n            nextLoopFolder\n          );\n          currentFolderContents[loopLevel].path = nextLoopFolder;\n          loopLevel+=1;\n        }\n      }\n\n      // true ==has more ids... (just loaded more)\n      return true;\n    }\n\n\n    const idsCurrentFolder = () => \n      currentFolderContents[currentFolderContents.length - 1].contents;\n\n    const fininshedResult = ({ done: true, result: { ids: [], collectionKey } });\n\n    let hasStarted = false;\n    let hasMore = true;\n    const getIdsFromCurrentfolder = async () => {\n\n      if(!hasMore) {\n        return fininshedResult;\n      }\n\n      if(!hasStarted) {\n        hasMore = await firstFolder();\n        hasStarted = true;\n        return ({\n          result: {\n            ids: idsCurrentFolder(),\n            collectionKey\n          },\n          done: false\n        })\n      }\n\n      hasMore = await getNextFolder();\n      \n      return ({\n        result: {\n          ids: hasMore ? idsCurrentFolder() : [],\n          collectionKey\n        },\n        done: !hasMore\n      });\n    }\n\n    return getIdsFromCurrentfolder;\n    \n  };\n\n  const ancestors = $(getFlattenedHierarchy(app.hierarchy), [\n    filter(isCollectionRecord),\n    filter(n => isAncestor(recordNode)(n)\n                    || n.nodeKey() === recordNode.nodeKey()),\n    orderBy([n => n.nodeKey().length], ['asc']),\n  ]); // parents first\n\n  const traverseForIteraterators = async (parentRecordKey = '', currentNodeIndex = 0) => {\n    const currentNode = ancestors[currentNodeIndex];\n    const currentCollectionKey = joinKey(\n      parentRecordKey,\n      currentNode.collectionName,\n    );\n    if (currentNode.nodeKey() === recordNode.nodeKey()) {\n      return [\n        await getAllIdsIteratorForCollectionKey(\n          currentNode,\n          currentCollectionKey,\n        )];\n    }\n    const allIterators = [];\n    const currentIterator = await getAllIdsIteratorForCollectionKey(\n      currentNode,\n      currentCollectionKey,\n    );\n\n    let ids = await currentIterator();\n    while (ids.done === false) {\n      for (const id of ids.result.ids) {\n        allIterators.push(\n          await traverseForIteraterators(\n            joinKey(currentCollectionKey, id),\n            currentNodeIndex + 1,\n          ),\n        );\n      }\n\n      ids = await currentIterator();\n    }\n\n    return flatten(allIterators);\n  };\n\n  const iteratorsArray = await traverseForIteraterators();\n  let currentIteratorIndex = 0;\n  return async () => {\n    if (iteratorsArray.length === 0) { return { done: true, result: [] }; }\n    const innerResult = await iteratorsArray[currentIteratorIndex]();\n    if (!innerResult.done) { return innerResult; }\n    if (currentIteratorIndex == iteratorsArray.length - 1) {\n      return { done: true, result: innerResult.result };\n    }\n    currentIteratorIndex++;\n    return { done: false, result: innerResult.result };\n  };\n};\n\n\nexport default getAllIdsIterator;\n","import { \n  getExactNodeForKey, getActualKeyOfParent, \n  isRoot, isSingleRecord, getNodeForCollectionPath\n} from '../templateApi/hierarchy';\nimport {\nreduce, find, filter, take\n} from 'lodash/fp';\nimport {\n$, getFileFromKey, joinKey, safeKey, keySep\n} from '../common';\nimport { \n    folderStructureArray, allIdChars \n} from \"../indexing/allIds\";\n\nexport const getRecordInfo = (hierarchy, key) => {\n  const recordNode = getExactNodeForKey(hierarchy)(key);\n  const pathInfo = getRecordDirectory(recordNode, key);\n  const dir = joinKey(pathInfo.base, ...pathInfo.subdirs);\n\n  return {\n    recordJson: recordJson(dir),\n    files: files(dir),\n    child:(name) => joinKey(dir, name),\n    key: safeKey(key),\n    recordNode, pathInfo, dir\n  };\n}\n\nexport const getCollectionDir = (hierarchy, collectionKey) => {\n  const recordNode = getNodeForCollectionPath(hierarchy)(collectionKey);\n  const dummyRecordKey = joinKey(collectionKey, \"1-abcd\");\n  const pathInfo = getRecordDirectory(recordNode, dummyRecordKey);\n  return pathInfo.base;\n}\n\nconst recordJson = (dir) => \n  joinKey(dir, \"record.json\")\n\nconst files = (dir) => \n  joinKey(dir, \"files\")\n\nconst getRecordDirectory = (recordNode, key) => {\n  const id = getFileFromKey(key);\n  \n  const traverseParentKeys = (n, parents=[]) => {\n    if(isRoot(n)) return parents;\n    const k = getActualKeyOfParent(n.nodeKey(), key);\n    const thisNodeDir = {\n      node:n,\n      relativeDir: joinKey(\n        recordRelativeDirectory(n, getFileFromKey(k)))\n    };\n    return traverseParentKeys(\n      n.parent(), \n      [thisNodeDir, ...parents]);\n  }\n\n  const parentDirs = $(recordNode.parent(), [\n    traverseParentKeys,\n    reduce((key, item) => {\n      return joinKey(key, item.node.collectionName, item.relativeDir)\n    }, keySep)\n  ]);\n\n  const subdirs = isSingleRecord(recordNode)\n                  ? []\n                  : recordRelativeDirectory(recordNode, id);\n  const base = isSingleRecord(recordNode)\n               ? joinKey(parentDirs, recordNode.name)\n               : joinKey(parentDirs, recordNode.collectionName);\n\n  return ({\n    subdirs, base\n  });\n}\n\nconst recordRelativeDirectory = (recordNode, id) => {\n  const folderStructure = folderStructureArray(recordNode);\n  const strippedId = id.substring(recordNode.nodeId.toString().length + 1);\n  const subfolders = $(folderStructure, [\n    reduce((result, currentCount) => {\n      result.folders.push(\n          folderForChar(strippedId[result.level], currentCount)\n      );\n      return {level:result.level+1, folders:result.folders};\n    }, {level:0, folders:[]}),\n    f => f.folders,\n    filter(f => !!f)\n  ]);\n\n  return [recordNode.nodeId.toString(), ...subfolders, id]\n}\n\nconst folderForChar = (char, folderCount) => \n  folderCount === 1 ? \"\"\n  : $(folderCount, [\n      idFoldersForFolderCount,\n      find(f => f.includes(char))\n    ]);\n\nconst idFoldersForFolderCount = (folderCount) => {\n  const charRangePerShard = 64 / folderCount;\n  const idFolders = [];\n  let index = 0;\n  let currentIdsShard = '';\n  while (index < 64) {\n    currentIdsShard += allIdChars[index];\n    if ((index + 1) % charRangePerShard === 0) {\n      idFolders.push(currentIdsShard);\n      currentIdsShard = '';\n    }\n    index++;\n  }\n    \n    return idFolders;\n};\n\n","import {\n  keyBy, mapValues, filter, \n  map, includes, last,\n} from 'lodash/fp';\nimport { getExactNodeForKey, getNode } from '../templateApi/hierarchy';\nimport { safeParseField } from '../types';\nimport {\n  $, splitKey, safeKey, isNonEmptyString,\n  apiWrapper, events, joinKey,\n} from '../common';\nimport { mapRecord } from '../indexing/evaluate';\nimport { permission } from '../authApi/permissions';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const getRecordFileName = key => joinKey(key, 'record.json');\n\nexport const load = app => async key => {\n  key = safeKey(key);\n  return apiWrapper(\n    app,\n    events.recordApi.load,\n    permission.readRecord.isAuthorized(key),\n    { key },\n    _load, app, key,\n  );\n}\n\nexport const _loadFromInfo = async (app, recordInfo, keyStack = []) => {\n  const key = recordInfo.key;\n  const {recordNode, recordJson} = recordInfo;\n  const storedData = await app.datastore.loadJson(recordJson);\n\n  const loadedRecord = $(recordNode.fields, [\n    keyBy('name'),\n    mapValues(f => safeParseField(f, storedData)),\n  ]);\n\n  const newKeyStack = [...keyStack, key];\n\n  const references = $(recordNode.fields, [\n    filter(f => f.type === 'reference'\n                    && isNonEmptyString(loadedRecord[f.name].key)\n                    && !includes(loadedRecord[f.name].key)(newKeyStack)),\n    map(f => ({\n      promise: _load(app, loadedRecord[f.name].key, newKeyStack),\n      index: getNode(app.hierarchy, f.typeOptions.indexNodeKey),\n      field: f,\n    })),\n  ]);\n\n  if (references.length > 0) {\n    const refRecords = await Promise.all(\n      map(p => p.promise)(references),\n    );\n\n    for (const ref of references) {\n      loadedRecord[ref.field.name] = mapRecord(\n        refRecords[references.indexOf(ref)],\n        ref.index,\n      );\n    }\n  }\n\n  loadedRecord.transactionId = storedData.transactionId;\n  loadedRecord.isNew = false;\n  loadedRecord.key = key;\n  loadedRecord.id = $(key, [splitKey, last]);\n  loadedRecord.type = recordNode.name;\n  return loadedRecord;\n};\n\nexport const _load = async (app, key, keyStack = []) => \n  _loadFromInfo(\n    app,\n    getRecordInfo(app.hierarchy, key),\n    keyStack);\n\n\nexport default load;\n","// adapted from https://github.com/dex4er/js-promise-readable\n// thanks :)\n  \nexport const promiseReadableStream = stream => {\n   \n    let _errored;\n\n    const _errorHandler = err => {\n        _errored = err;\n    };\n\n    stream.on(\"error\", _errorHandler);\n  \n    const read = (size) => {\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err)\n        }\n  \n        if (!stream.readable || stream.closed || stream.destroyed) {\n          return resolve();\n        }\n  \n        const readableHandler = () => {\n          const chunk = stream.read(size);\n  \n          if (chunk) {\n            removeListeners();\n            resolve(chunk);\n          }\n        }\n  \n        const closeHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const endHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const errorHandler = (err) => {\n          _errored = undefined;\n          removeListeners();\n          reject(err);\n        }\n  \n        const removeListeners = () => {\n          stream.removeListener(\"close\", closeHandler);\n          stream.removeListener(\"error\", errorHandler);\n          stream.removeListener(\"end\", endHandler);\n          stream.removeListener(\"readable\", readableHandler);\n        }\n  \n        stream.on(\"close\", closeHandler);\n        stream.on(\"end\", endHandler);\n        stream.on(\"error\", errorHandler);\n        stream.on(\"readable\", readableHandler);\n  \n        readableHandler();\n      });\n    }\n  \n  \n    const destroy = () => {\n      if (stream) {\n        if (_errorHandler) {\n          stream.removeListener(\"error\", _errorHandler);\n        }\n        if (typeof stream.destroy === \"function\") {\n          stream.destroy();\n        }\n      }\n    };\n  \n    return {read, destroy, stream};\n  }\n  \n  export default promiseReadableStream\n  ","import { compileCode } from '@nx-js/compiler-util';\nimport {\n  filter, includes, map, last,\n} from 'lodash/fp';\nimport {\n  getActualKeyOfParent, isGlobalIndex,\n  getParentKey, isShardedIndex,\n  getExactNodeForKey,\n} from '../templateApi/hierarchy';\nimport {\n  joinKey, isNonEmptyString, splitKey, $,\n} from '../common';\n\nexport const getIndexedDataKey = (indexNode, indexDir, record) => {\n  \n  const getShardName = (indexNode, record) => {\n    const shardNameFunc = compileCode(indexNode.getShardName);\n    try {\n      return shardNameFunc({ record });\n    } catch(e) {\n      const errorDetails = `shardCode: ${indexNode.getShardName} :: record: ${JSON.stringify(record)} :: `\n      e.message = \"Error running index shardname func: \" + errorDetails + e.message;\n      throw e;\n    }\n  };\n\n  const shardName = isNonEmptyString(indexNode.getShardName)\n    ? `${getShardName(indexNode, record)}.csv`\n    : 'index.csv';\n\n  return joinKey(indexDir, shardName);\n};\n\nexport const getShardKeysInRange = async (app, indexNode, indexDir, startRecord = null, endRecord = null) => {\n  const startShardName = !startRecord\n    ? null\n    : shardNameFromKey(\n      getIndexedDataKey(\n        indexNode,\n        indexDir,\n        startRecord,\n      ),\n    );\n\n  const endShardName = !endRecord\n    ? null\n    : shardNameFromKey(\n      getIndexedDataKey(\n        indexNode,\n        indexDir,\n        endRecord,\n      ),\n    );\n\n  return $(await getShardMap(app.datastore, indexDir), [\n    filter(k => (startRecord === null || k >= startShardName)\n                    && (endRecord === null || k <= endShardName)),\n    map(k => joinKey(indexDir, `${k}.csv`)),\n  ]);\n};\n\nexport const ensureShardNameIsInShardMap = async (store, indexDir, indexedDataKey) => {\n  const map = await getShardMap(store, indexDir);\n  const shardName = shardNameFromKey(indexedDataKey);\n  if (!includes(shardName)(map)) {\n    map.push(shardName);\n    await writeShardMap(store, indexDir, map);\n  }\n};\n\nexport const getShardMap = async (datastore, indexDir) => {\n  const shardMapKey = getShardMapKey(indexDir);\n  try {\n    return await datastore.loadJson(shardMapKey);\n  } catch (_) {\n    await datastore.createJson(shardMapKey, []);\n    return [];\n  }\n};\n\nexport const writeShardMap = async (datastore, indexDir, shardMap) => await datastore.updateJson(\n  getShardMapKey(indexDir),\n  shardMap,\n);\n\nexport const getAllShardKeys = async (app, indexNode, indexDir) =>\n  await getShardKeysInRange(app, indexNode, indexDir);\n\nexport const getShardMapKey = indexDir => joinKey(indexDir, 'shardMap.json');\n\nexport const getUnshardedIndexDataKey = indexDir => joinKey(indexDir, 'index.csv');\n\nexport const createIndexFile = async (datastore, indexedDataKey, index) => {\n  if (isShardedIndex(index)) {\n    const indexDir = getParentKey(indexedDataKey);\n    const shardMap = await getShardMap(datastore, indexDir);\n    shardMap.push(\n      shardNameFromKey(indexedDataKey),\n    );\n    await writeShardMap(datastore, indexDir, shardMap);\n  }\n  await datastore.createFile(indexedDataKey, '');\n};\n\nexport const shardNameFromKey = key => $(key, [\n  splitKey,\n  last,\n]).replace('.csv', '');\n\nexport const getIndexKey_BasedOnDecendant = (decendantKey, indexNode) => {\n  if (isGlobalIndex(indexNode)) { return `${indexNode.nodeKey()}`; }\n\n  const indexedDataParentKey = getActualKeyOfParent(\n    indexNode.parent().nodeKey(),\n    decendantKey,\n  );\n\n  return joinKey(\n    indexedDataParentKey,\n    indexNode.name,\n  );\n};\n","import {\n  has, keys, map, orderBy,\n  filter, concat, reverse,\n} from 'lodash/fp';\nimport { getAllowedRecordNodesForIndex } from '../templateApi/hierarchy';\nimport { mapRecord } from './evaluate';\nimport { constructRecord } from '../recordApi/getNew';\nimport { getSampleFieldValue, detectType, all } from '../types';\nimport { $ } from '../common';\n\nexport const generateSchema = (hierarchy, indexNode) => {\n  const recordNodes = getAllowedRecordNodesForIndex(hierarchy, indexNode);\n  const mappedRecords = $(recordNodes, [\n    map(n => mapRecord(createSampleRecord(n), indexNode)),\n  ]);\n\n  // always has record key and sort key\n  const schema = {\n    sortKey: all.string,\n    key: all.string,\n  };\n\n  const fieldsHas = has(schema);\n  const setField = (fieldName, value) => {\n    if (value === null || value === undefined) { return; }\n\n    const thisType = detectType(value);\n    if (fieldsHas(fieldName)) {\n      if (schema[fieldName] !== thisType) {\n        schema[fieldName] = all.string;\n      }\n    } else {\n      schema[fieldName] = thisType;\n    }\n  };\n\n  for (const mappedRec of mappedRecords) {\n    for (const f in mappedRec) {\n      setField(f, mappedRec[f]);\n    }\n  }\n\n  // returing an array of {name, type}\n  return $(schema, [\n    keys,\n    map(k => ({ name: k, type: schema[k].name })),\n    filter(s => s.name !== 'sortKey'),\n    orderBy('name', ['desc']), // reverse aplha\n    concat([{ name: 'sortKey', type: all.string.name }]), // sortKey on end\n    reverse, // sortKey first, then rest are alphabetical\n  ]);\n};\n\nconst createSampleRecord = recordNode => constructRecord(\n  recordNode,\n  getSampleFieldValue,\n  recordNode.parent().nodeKey(),\n);\n","export default (typeof global !== \"undefined\" ? global :\n            typeof self !== \"undefined\" ? self :\n            typeof window !== \"undefined\" ? window : {});\n","\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\nvar inited = false;\nfunction init () {\n  inited = true;\n  var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\n  for (var i = 0, len = code.length; i < len; ++i) {\n    lookup[i] = code[i]\n    revLookup[code.charCodeAt(i)] = i\n  }\n\n  revLookup['-'.charCodeAt(0)] = 62\n  revLookup['_'.charCodeAt(0)] = 63\n}\n\nexport function toByteArray (b64) {\n  if (!inited) {\n    init();\n  }\n  var i, j, l, tmp, placeHolders, arr\n  var len = b64.length\n\n  if (len % 4 > 0) {\n    throw new Error('Invalid string. Length must be a multiple of 4')\n  }\n\n  // the number of equal signs (place holders)\n  // if there are two placeholders, than the two characters before it\n  // represent one byte\n  // if there is only one, then the three characters before it represent 2 bytes\n  // this is just a cheap hack to not do indexOf twice\n  placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n\n  // base64 is 4/3 + up to two characters of the original data\n  arr = new Arr(len * 3 / 4 - placeHolders)\n\n  // if there are placeholders, only get up to the last complete 4 chars\n  l = placeHolders > 0 ? len - 4 : len\n\n  var L = 0\n\n  for (i = 0, j = 0; i < l; i += 4, j += 3) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n    arr[L++] = (tmp >> 16) & 0xFF\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  if (placeHolders === 2) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n    arr[L++] = tmp & 0xFF\n  } else if (placeHolders === 1) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  return arr\n}\n\nfunction tripletToBase64 (num) {\n  return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n  var tmp\n  var output = []\n  for (var i = start; i < end; i += 3) {\n    tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n    output.push(tripletToBase64(tmp))\n  }\n  return output.join('')\n}\n\nexport function fromByteArray (uint8) {\n  if (!inited) {\n    init();\n  }\n  var tmp\n  var len = uint8.length\n  var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n  var output = ''\n  var parts = []\n  var maxChunkLength = 16383 // must be multiple of 3\n\n  // go through the array every three bytes, we'll deal with trailing stuff later\n  for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n    parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n  }\n\n  // pad the end with zeros, but make sure to not forget the extra bytes\n  if (extraBytes === 1) {\n    tmp = uint8[len - 1]\n    output += lookup[tmp >> 2]\n    output += lookup[(tmp << 4) & 0x3F]\n    output += '=='\n  } else if (extraBytes === 2) {\n    tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n    output += lookup[tmp >> 10]\n    output += lookup[(tmp >> 4) & 0x3F]\n    output += lookup[(tmp << 2) & 0x3F]\n    output += '='\n  }\n\n  parts.push(output)\n\n  return parts.join('')\n}\n","\nexport function read (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexport function write (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","var toString = {}.toString;\n\nexport default Array.isArray || function (arr) {\n  return toString.call(arr) == '[object Array]';\n};\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n/* eslint-disable no-proto */\n\n\nimport * as base64 from './base64'\nimport * as ieee754 from './ieee754'\nimport isArray from './isArray'\n\nexport var INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n *   - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n *     See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *   - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n *   - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n *     incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n  ? global.TYPED_ARRAY_SUPPORT\n  : true\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nvar _kMaxLength = kMaxLength()\nexport {_kMaxLength as kMaxLength};\nfunction typedArraySupport () {\n  return true;\n  // rollup issues\n  // try {\n  //   var arr = new Uint8Array(1)\n  //   arr.__proto__ = {\n  //     __proto__: Uint8Array.prototype,\n  //     foo: function () { return 42 }\n  //   }\n  //   return arr.foo() === 42 && // typed array instances can be augmented\n  //       typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n  //       arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  // } catch (e) {\n  //   return false\n  // }\n}\n\nfunction kMaxLength () {\n  return Buffer.TYPED_ARRAY_SUPPORT\n    ? 0x7fffffff\n    : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n  if (kMaxLength() < length) {\n    throw new RangeError('Invalid typed array length')\n  }\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = new Uint8Array(length)\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    if (that === null) {\n      that = new Buffer(length)\n    }\n    that.length = length\n  }\n\n  return that\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nexport function Buffer (arg, encodingOrOffset, length) {\n  if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n    return new Buffer(arg, encodingOrOffset, length)\n  }\n\n  // Common case.\n  if (typeof arg === 'number') {\n    if (typeof encodingOrOffset === 'string') {\n      throw new Error(\n        'If encoding is specified then the first argument must be a string'\n      )\n    }\n    return allocUnsafe(this, arg)\n  }\n  return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n  arr.__proto__ = Buffer.prototype\n  return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n  if (typeof value === 'number') {\n    throw new TypeError('\"value\" argument must not be a number')\n  }\n\n  if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n    return fromArrayBuffer(that, value, encodingOrOffset, length)\n  }\n\n  if (typeof value === 'string') {\n    return fromString(that, value, encodingOrOffset)\n  }\n\n  return fromObject(that, value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n  return from(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n  Buffer.prototype.__proto__ = Uint8Array.prototype\n  Buffer.__proto__ = Uint8Array\n  if (typeof Symbol !== 'undefined' && Symbol.species &&\n      Buffer[Symbol.species] === Buffer) {\n    // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n    // Object.defineProperty(Buffer, Symbol.species, {\n    //   value: null,\n    //   configurable: true\n    // })\n  }\n}\n\nfunction assertSize (size) {\n  if (typeof size !== 'number') {\n    throw new TypeError('\"size\" argument must be a number')\n  } else if (size < 0) {\n    throw new RangeError('\"size\" argument must not be negative')\n  }\n}\n\nfunction alloc (that, size, fill, encoding) {\n  assertSize(size)\n  if (size <= 0) {\n    return createBuffer(that, size)\n  }\n  if (fill !== undefined) {\n    // Only pay attention to encoding if it's a string. This\n    // prevents accidentally sending in a number that would\n    // be interpretted as a start offset.\n    return typeof encoding === 'string'\n      ? createBuffer(that, size).fill(fill, encoding)\n      : createBuffer(that, size).fill(fill)\n  }\n  return createBuffer(that, size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n  return alloc(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n  assertSize(size)\n  that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < size; ++i) {\n      that[i] = 0\n    }\n  }\n  return that\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n  return allocUnsafe(null, size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n  return allocUnsafe(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') {\n    encoding = 'utf8'\n  }\n\n  if (!Buffer.isEncoding(encoding)) {\n    throw new TypeError('\"encoding\" must be a valid string encoding')\n  }\n\n  var length = byteLength(string, encoding) | 0\n  that = createBuffer(that, length)\n\n  var actual = that.write(string, encoding)\n\n  if (actual !== length) {\n    // Writing a hex string, for example, that contains invalid characters will\n    // cause everything after the first invalid character to be ignored. (e.g.\n    // 'abxxcd' will be treated as 'ab')\n    that = that.slice(0, actual)\n  }\n\n  return that\n}\n\nfunction fromArrayLike (that, array) {\n  var length = array.length < 0 ? 0 : checked(array.length) | 0\n  that = createBuffer(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n  array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n  if (byteOffset < 0 || array.byteLength < byteOffset) {\n    throw new RangeError('\\'offset\\' is out of bounds')\n  }\n\n  if (array.byteLength < byteOffset + (length || 0)) {\n    throw new RangeError('\\'length\\' is out of bounds')\n  }\n\n  if (byteOffset === undefined && length === undefined) {\n    array = new Uint8Array(array)\n  } else if (length === undefined) {\n    array = new Uint8Array(array, byteOffset)\n  } else {\n    array = new Uint8Array(array, byteOffset, length)\n  }\n\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = array\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that = fromArrayLike(that, array)\n  }\n  return that\n}\n\nfunction fromObject (that, obj) {\n  if (internalIsBuffer(obj)) {\n    var len = checked(obj.length) | 0\n    that = createBuffer(that, len)\n\n    if (that.length === 0) {\n      return that\n    }\n\n    obj.copy(that, 0, 0, len)\n    return that\n  }\n\n  if (obj) {\n    if ((typeof ArrayBuffer !== 'undefined' &&\n        obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n      if (typeof obj.length !== 'number' || isnan(obj.length)) {\n        return createBuffer(that, 0)\n      }\n      return fromArrayLike(that, obj)\n    }\n\n    if (obj.type === 'Buffer' && isArray(obj.data)) {\n      return fromArrayLike(that, obj.data)\n    }\n  }\n\n  throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < kMaxLength()` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= kMaxLength()) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + kMaxLength().toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nexport function SlowBuffer (length) {\n  if (+length != length) { // eslint-disable-line eqeqeq\n    length = 0\n  }\n  return Buffer.alloc(+length)\n}\nBuffer.isBuffer = isBuffer;\nfunction internalIsBuffer (b) {\n  return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n  if (!internalIsBuffer(a) || !internalIsBuffer(b)) {\n    throw new TypeError('Arguments must be Buffers')\n  }\n\n  if (a === b) return 0\n\n  var x = a.length\n  var y = b.length\n\n  for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n    if (a[i] !== b[i]) {\n      x = a[i]\n      y = b[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'latin1':\n    case 'binary':\n    case 'base64':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function concat (list, length) {\n  if (!isArray(list)) {\n    throw new TypeError('\"list\" argument must be an Array of Buffers')\n  }\n\n  if (list.length === 0) {\n    return Buffer.alloc(0)\n  }\n\n  var i\n  if (length === undefined) {\n    length = 0\n    for (i = 0; i < list.length; ++i) {\n      length += list[i].length\n    }\n  }\n\n  var buffer = Buffer.allocUnsafe(length)\n  var pos = 0\n  for (i = 0; i < list.length; ++i) {\n    var buf = list[i]\n    if (!internalIsBuffer(buf)) {\n      throw new TypeError('\"list\" argument must be an Array of Buffers')\n    }\n    buf.copy(buffer, pos)\n    pos += buf.length\n  }\n  return buffer\n}\n\nfunction byteLength (string, encoding) {\n  if (internalIsBuffer(string)) {\n    return string.length\n  }\n  if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n      (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n    return string.byteLength\n  }\n  if (typeof string !== 'string') {\n    string = '' + string\n  }\n\n  var len = string.length\n  if (len === 0) return 0\n\n  // Use a for loop to avoid recursion\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'ascii':\n      case 'latin1':\n      case 'binary':\n        return len\n      case 'utf8':\n      case 'utf-8':\n      case undefined:\n        return utf8ToBytes(string).length\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return len * 2\n      case 'hex':\n        return len >>> 1\n      case 'base64':\n        return base64ToBytes(string).length\n      default:\n        if (loweredCase) return utf8ToBytes(string).length // assume utf8\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n  var loweredCase = false\n\n  // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n  // property of a typed array.\n\n  // This behaves neither like String nor Uint8Array in that we set start/end\n  // to their upper/lower bounds if the value passed is out of range.\n  // undefined is handled specially as per ECMA-262 6th Edition,\n  // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n  if (start === undefined || start < 0) {\n    start = 0\n  }\n  // Return early if start > this.length. Done here to prevent potential uint32\n  // coercion fail below.\n  if (start > this.length) {\n    return ''\n  }\n\n  if (end === undefined || end > this.length) {\n    end = this.length\n  }\n\n  if (end <= 0) {\n    return ''\n  }\n\n  // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n  end >>>= 0\n  start >>>= 0\n\n  if (end <= start) {\n    return ''\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Slice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n  var i = b[n]\n  b[n] = b[m]\n  b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n  var len = this.length\n  if (len % 2 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 16-bits')\n  }\n  for (var i = 0; i < len; i += 2) {\n    swap(this, i, i + 1)\n  }\n  return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n  var len = this.length\n  if (len % 4 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 32-bits')\n  }\n  for (var i = 0; i < len; i += 4) {\n    swap(this, i, i + 3)\n    swap(this, i + 1, i + 2)\n  }\n  return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n  var len = this.length\n  if (len % 8 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 64-bits')\n  }\n  for (var i = 0; i < len; i += 8) {\n    swap(this, i, i + 7)\n    swap(this, i + 1, i + 6)\n    swap(this, i + 2, i + 5)\n    swap(this, i + 3, i + 4)\n  }\n  return this\n}\n\nBuffer.prototype.toString = function toString () {\n  var length = this.length | 0\n  if (length === 0) return ''\n  if (arguments.length === 0) return utf8Slice(this, 0, length)\n  return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n  if (!internalIsBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return true\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n  var str = ''\n  var max = INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max) str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n  if (!internalIsBuffer(target)) {\n    throw new TypeError('Argument must be a Buffer')\n  }\n\n  if (start === undefined) {\n    start = 0\n  }\n  if (end === undefined) {\n    end = target ? target.length : 0\n  }\n  if (thisStart === undefined) {\n    thisStart = 0\n  }\n  if (thisEnd === undefined) {\n    thisEnd = this.length\n  }\n\n  if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n    throw new RangeError('out of range index')\n  }\n\n  if (thisStart >= thisEnd && start >= end) {\n    return 0\n  }\n  if (thisStart >= thisEnd) {\n    return -1\n  }\n  if (start >= end) {\n    return 1\n  }\n\n  start >>>= 0\n  end >>>= 0\n  thisStart >>>= 0\n  thisEnd >>>= 0\n\n  if (this === target) return 0\n\n  var x = thisEnd - thisStart\n  var y = end - start\n  var len = Math.min(x, y)\n\n  var thisCopy = this.slice(thisStart, thisEnd)\n  var targetCopy = target.slice(start, end)\n\n  for (var i = 0; i < len; ++i) {\n    if (thisCopy[i] !== targetCopy[i]) {\n      x = thisCopy[i]\n      y = targetCopy[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n  // Empty buffer means no match\n  if (buffer.length === 0) return -1\n\n  // Normalize byteOffset\n  if (typeof byteOffset === 'string') {\n    encoding = byteOffset\n    byteOffset = 0\n  } else if (byteOffset > 0x7fffffff) {\n    byteOffset = 0x7fffffff\n  } else if (byteOffset < -0x80000000) {\n    byteOffset = -0x80000000\n  }\n  byteOffset = +byteOffset  // Coerce to Number.\n  if (isNaN(byteOffset)) {\n    // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n    byteOffset = dir ? 0 : (buffer.length - 1)\n  }\n\n  // Normalize byteOffset: negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n  if (byteOffset >= buffer.length) {\n    if (dir) return -1\n    else byteOffset = buffer.length - 1\n  } else if (byteOffset < 0) {\n    if (dir) byteOffset = 0\n    else return -1\n  }\n\n  // Normalize val\n  if (typeof val === 'string') {\n    val = Buffer.from(val, encoding)\n  }\n\n  // Finally, search either indexOf (if dir is true) or lastIndexOf\n  if (internalIsBuffer(val)) {\n    // Special case: looking for empty string/buffer always fails\n    if (val.length === 0) {\n      return -1\n    }\n    return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n  } else if (typeof val === 'number') {\n    val = val & 0xFF // Search for a byte value [0-255]\n    if (Buffer.TYPED_ARRAY_SUPPORT &&\n        typeof Uint8Array.prototype.indexOf === 'function') {\n      if (dir) {\n        return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n      } else {\n        return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n      }\n    }\n    return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n  var indexSize = 1\n  var arrLength = arr.length\n  var valLength = val.length\n\n  if (encoding !== undefined) {\n    encoding = String(encoding).toLowerCase()\n    if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n        encoding === 'utf16le' || encoding === 'utf-16le') {\n      if (arr.length < 2 || val.length < 2) {\n        return -1\n      }\n      indexSize = 2\n      arrLength /= 2\n      valLength /= 2\n      byteOffset /= 2\n    }\n  }\n\n  function read (buf, i) {\n    if (indexSize === 1) {\n      return buf[i]\n    } else {\n      return buf.readUInt16BE(i * indexSize)\n    }\n  }\n\n  var i\n  if (dir) {\n    var foundIndex = -1\n    for (i = byteOffset; i < arrLength; i++) {\n      if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n      } else {\n        if (foundIndex !== -1) i -= i - foundIndex\n        foundIndex = -1\n      }\n    }\n  } else {\n    if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n    for (i = byteOffset; i >= 0; i--) {\n      var found = true\n      for (var j = 0; j < valLength; j++) {\n        if (read(arr, i + j) !== read(val, j)) {\n          found = false\n          break\n        }\n      }\n      if (found) return i\n    }\n  }\n\n  return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n  return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; ++i) {\n    var parsed = parseInt(string.substr(i * 2, 2), 16)\n    if (isNaN(parsed)) return i\n    buf[offset + i] = parsed\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n  return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n  // Buffer#write(string)\n  if (offset === undefined) {\n    encoding = 'utf8'\n    length = this.length\n    offset = 0\n  // Buffer#write(string, encoding)\n  } else if (length === undefined && typeof offset === 'string') {\n    encoding = offset\n    length = this.length\n    offset = 0\n  // Buffer#write(string, offset[, length][, encoding])\n  } else if (isFinite(offset)) {\n    offset = offset | 0\n    if (isFinite(length)) {\n      length = length | 0\n      if (encoding === undefined) encoding = 'utf8'\n    } else {\n      encoding = length\n      length = undefined\n    }\n  // legacy write(string, encoding, offset, length) - remove in v0.13\n  } else {\n    throw new Error(\n      'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n    )\n  }\n\n  var remaining = this.length - offset\n  if (length === undefined || length > remaining) length = remaining\n\n  if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n    throw new RangeError('Attempt to write outside buffer bounds')\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'hex':\n        return hexWrite(this, string, offset, length)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Write(this, string, offset, length)\n\n      case 'ascii':\n        return asciiWrite(this, string, offset, length)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Write(this, string, offset, length)\n\n      case 'base64':\n        // Warning: maxLength not taken into account in base64Write\n        return base64Write(this, string, offset, length)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return ucs2Write(this, string, offset, length)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  end = Math.min(buf.length, end)\n  var res = []\n\n  var i = start\n  while (i < end) {\n    var firstByte = buf[i]\n    var codePoint = null\n    var bytesPerSequence = (firstByte > 0xEF) ? 4\n      : (firstByte > 0xDF) ? 3\n      : (firstByte > 0xBF) ? 2\n      : 1\n\n    if (i + bytesPerSequence <= end) {\n      var secondByte, thirdByte, fourthByte, tempCodePoint\n\n      switch (bytesPerSequence) {\n        case 1:\n          if (firstByte < 0x80) {\n            codePoint = firstByte\n          }\n          break\n        case 2:\n          secondByte = buf[i + 1]\n          if ((secondByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n            if (tempCodePoint > 0x7F) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 3:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n            if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 4:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          fourthByte = buf[i + 3]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n            if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n              codePoint = tempCodePoint\n            }\n          }\n      }\n    }\n\n    if (codePoint === null) {\n      // we did not generate a valid codePoint so insert a\n      // replacement char (U+FFFD) and advance only 1 byte\n      codePoint = 0xFFFD\n      bytesPerSequence = 1\n    } else if (codePoint > 0xFFFF) {\n      // encode to utf16 (surrogate pair dance)\n      codePoint -= 0x10000\n      res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n      codePoint = 0xDC00 | codePoint & 0x3FF\n    }\n\n    res.push(codePoint)\n    i += bytesPerSequence\n  }\n\n  return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n  var len = codePoints.length\n  if (len <= MAX_ARGUMENTS_LENGTH) {\n    return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n  }\n\n  // Decode in chunks to avoid \"call stack size exceeded\".\n  var res = ''\n  var i = 0\n  while (i < len) {\n    res += String.fromCharCode.apply(\n      String,\n      codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n    )\n  }\n  return res\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i] & 0x7F)\n  }\n  return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; ++i) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len\n    if (start < 0) start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0) end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start) end = start\n\n  var newBuf\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    newBuf = this.subarray(start, end)\n    newBuf.__proto__ = Buffer.prototype\n  } else {\n    var sliceLen = end - start\n    newBuf = new Buffer(sliceLen, undefined)\n    for (var i = 0; i < sliceLen; ++i) {\n      newBuf[i] = this[i + start]\n    }\n  }\n\n  return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n  if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    checkOffset(offset, byteLength, this.length)\n  }\n\n  var val = this[offset + --byteLength]\n  var mul = 1\n  while (byteLength > 0 && (mul *= 0x100)) {\n    val += this[offset + --byteLength] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n    ((this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var i = byteLength\n  var mul = 1\n  var val = this[offset + --i]\n  while (i > 0 && (mul *= 0x100)) {\n    val += this[offset + --i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80)) return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n    (this[offset + 1] << 8) |\n    (this[offset + 2] << 16) |\n    (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n    (this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!internalIsBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n  if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var mul = 1\n  var i = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n    buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n      (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffffffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n    buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset + 3] = (value >>> 24)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 1] = (value >>> 8)\n    this[offset] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = 0\n  var mul = 1\n  var sub = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  var sub = 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n  if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (targetStart >= target.length) targetStart = target.length\n  if (!targetStart) targetStart = 0\n  if (end > 0 && end < start) end = start\n\n  // Copy 0 bytes; we're done\n  if (end === start) return 0\n  if (target.length === 0 || this.length === 0) return 0\n\n  // Fatal error conditions\n  if (targetStart < 0) {\n    throw new RangeError('targetStart out of bounds')\n  }\n  if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n  if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length) end = this.length\n  if (target.length - targetStart < end - start) {\n    end = target.length - targetStart + start\n  }\n\n  var len = end - start\n  var i\n\n  if (this === target && start < targetStart && targetStart < end) {\n    // descending copy from end\n    for (i = len - 1; i >= 0; --i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    // ascending copy from start\n    for (i = 0; i < len; ++i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    Uint8Array.prototype.set.call(\n      target,\n      this.subarray(start, start + len),\n      targetStart\n    )\n  }\n\n  return len\n}\n\n// Usage:\n//    buffer.fill(number[, offset[, end]])\n//    buffer.fill(buffer[, offset[, end]])\n//    buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n  // Handle string cases:\n  if (typeof val === 'string') {\n    if (typeof start === 'string') {\n      encoding = start\n      start = 0\n      end = this.length\n    } else if (typeof end === 'string') {\n      encoding = end\n      end = this.length\n    }\n    if (val.length === 1) {\n      var code = val.charCodeAt(0)\n      if (code < 256) {\n        val = code\n      }\n    }\n    if (encoding !== undefined && typeof encoding !== 'string') {\n      throw new TypeError('encoding must be a string')\n    }\n    if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n      throw new TypeError('Unknown encoding: ' + encoding)\n    }\n  } else if (typeof val === 'number') {\n    val = val & 255\n  }\n\n  // Invalid ranges are not set to a default, so can range check early.\n  if (start < 0 || this.length < start || this.length < end) {\n    throw new RangeError('Out of range index')\n  }\n\n  if (end <= start) {\n    return this\n  }\n\n  start = start >>> 0\n  end = end === undefined ? this.length : end >>> 0\n\n  if (!val) val = 0\n\n  var i\n  if (typeof val === 'number') {\n    for (i = start; i < end; ++i) {\n      this[i] = val\n    }\n  } else {\n    var bytes = internalIsBuffer(val)\n      ? val\n      : utf8ToBytes(new Buffer(val, encoding).toString())\n    var len = bytes.length\n    for (i = 0; i < end - start; ++i) {\n      this[i + start] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n  // Node converts strings with length < 2 to ''\n  if (str.length < 2) return ''\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n  units = units || Infinity\n  var codePoint\n  var length = string.length\n  var leadSurrogate = null\n  var bytes = []\n\n  for (var i = 0; i < length; ++i) {\n    codePoint = string.charCodeAt(i)\n\n    // is surrogate component\n    if (codePoint > 0xD7FF && codePoint < 0xE000) {\n      // last char was a lead\n      if (!leadSurrogate) {\n        // no lead yet\n        if (codePoint > 0xDBFF) {\n          // unexpected trail\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        } else if (i + 1 === length) {\n          // unpaired lead\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        }\n\n        // valid lead\n        leadSurrogate = codePoint\n\n        continue\n      }\n\n      // 2 leads in a row\n      if (codePoint < 0xDC00) {\n        if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n        leadSurrogate = codePoint\n        continue\n      }\n\n      // valid surrogate pair\n      codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n    } else if (leadSurrogate) {\n      // valid bmp char, but last char was a lead\n      if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n    }\n\n    leadSurrogate = null\n\n    // encode utf8\n    if (codePoint < 0x80) {\n      if ((units -= 1) < 0) break\n      bytes.push(codePoint)\n    } else if (codePoint < 0x800) {\n      if ((units -= 2) < 0) break\n      bytes.push(\n        codePoint >> 0x6 | 0xC0,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x10000) {\n      if ((units -= 3) < 0) break\n      bytes.push(\n        codePoint >> 0xC | 0xE0,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x110000) {\n      if ((units -= 4) < 0) break\n      bytes.push(\n        codePoint >> 0x12 | 0xF0,\n        codePoint >> 0xC & 0x3F | 0x80,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else {\n      throw new Error('Invalid code point')\n    }\n  }\n\n  return bytes\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    if ((units -= 2) < 0) break\n\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  for (var i = 0; i < length; ++i) {\n    if ((i + offset >= dst.length) || (i >= src.length)) break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\nfunction isnan (val) {\n  return val !== val // eslint-disable-line no-self-compare\n}\n\n\n// the following is from is-buffer, also by Feross Aboukhadijeh and with same lisence\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nexport function isBuffer(obj) {\n  return obj != null && (!!obj._isBuffer || isFastBuffer(obj) || isSlowBuffer(obj))\n}\n\nfunction isFastBuffer (obj) {\n  return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n  return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isFastBuffer(obj.slice(0, 0))\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nimport {Buffer} from 'buffer';\nvar isBufferEncoding = Buffer.isEncoding\n  || function(encoding) {\n       switch (encoding && encoding.toLowerCase()) {\n         case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true;\n         default: return false;\n       }\n     }\n\n\nfunction assertEncoding(encoding) {\n  if (encoding && !isBufferEncoding(encoding)) {\n    throw new Error('Unknown encoding: ' + encoding);\n  }\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters. CESU-8 is handled as part of the UTF-8 encoding.\n//\n// @TODO Handling all encodings inside a single object makes it very difficult\n// to reason about this code, so it should be split up in the future.\n// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code\n// points as used by CESU-8.\nexport function StringDecoder(encoding) {\n  this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, '');\n  assertEncoding(encoding);\n  switch (this.encoding) {\n    case 'utf8':\n      // CESU-8 represents each of Surrogate Pair by 3-bytes\n      this.surrogateSize = 3;\n      break;\n    case 'ucs2':\n    case 'utf16le':\n      // UTF-16 represents each of Surrogate Pair by 2-bytes\n      this.surrogateSize = 2;\n      this.detectIncompleteChar = utf16DetectIncompleteChar;\n      break;\n    case 'base64':\n      // Base-64 stores 3 bytes in 4 chars, and pads the remainder.\n      this.surrogateSize = 3;\n      this.detectIncompleteChar = base64DetectIncompleteChar;\n      break;\n    default:\n      this.write = passThroughWrite;\n      return;\n  }\n\n  // Enough space to store all bytes of a single character. UTF-8 needs 4\n  // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate).\n  this.charBuffer = new Buffer(6);\n  // Number of bytes received for the current incomplete multi-byte character.\n  this.charReceived = 0;\n  // Number of bytes expected for the current incomplete multi-byte character.\n  this.charLength = 0;\n};\n\n\n// write decodes the given buffer and returns it as JS string that is\n// guaranteed to not contain any partial multi-byte characters. Any partial\n// character found at the end of the buffer is buffered up, and will be\n// returned when calling write again with the remaining bytes.\n//\n// Note: Converting a Buffer containing an orphan surrogate to a String\n// currently works, but converting a String to a Buffer (via `new Buffer`, or\n// Buffer#write) will replace incomplete surrogates with the unicode\n// replacement character. See https://codereview.chromium.org/121173009/ .\nStringDecoder.prototype.write = function(buffer) {\n  var charStr = '';\n  // if our last write ended with an incomplete multibyte character\n  while (this.charLength) {\n    // determine how many remaining bytes this buffer has to offer for this char\n    var available = (buffer.length >= this.charLength - this.charReceived) ?\n        this.charLength - this.charReceived :\n        buffer.length;\n\n    // add the new bytes to the char buffer\n    buffer.copy(this.charBuffer, this.charReceived, 0, available);\n    this.charReceived += available;\n\n    if (this.charReceived < this.charLength) {\n      // still not enough chars in this buffer? wait for more ...\n      return '';\n    }\n\n    // remove bytes belonging to the current character from the buffer\n    buffer = buffer.slice(available, buffer.length);\n\n    // get the character that was split\n    charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding);\n\n    // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n    var charCode = charStr.charCodeAt(charStr.length - 1);\n    if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n      this.charLength += this.surrogateSize;\n      charStr = '';\n      continue;\n    }\n    this.charReceived = this.charLength = 0;\n\n    // if there are no more bytes in this buffer, just emit our char\n    if (buffer.length === 0) {\n      return charStr;\n    }\n    break;\n  }\n\n  // determine and set charLength / charReceived\n  this.detectIncompleteChar(buffer);\n\n  var end = buffer.length;\n  if (this.charLength) {\n    // buffer the incomplete character bytes we got\n    buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end);\n    end -= this.charReceived;\n  }\n\n  charStr += buffer.toString(this.encoding, 0, end);\n\n  var end = charStr.length - 1;\n  var charCode = charStr.charCodeAt(end);\n  // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n  if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n    var size = this.surrogateSize;\n    this.charLength += size;\n    this.charReceived += size;\n    this.charBuffer.copy(this.charBuffer, size, 0, size);\n    buffer.copy(this.charBuffer, 0, 0, size);\n    return charStr.substring(0, end);\n  }\n\n  // or just emit the charStr\n  return charStr;\n};\n\n// detectIncompleteChar determines if there is an incomplete UTF-8 character at\n// the end of the given buffer. If so, it sets this.charLength to the byte\n// length that character, and sets this.charReceived to the number of bytes\n// that are available for this character.\nStringDecoder.prototype.detectIncompleteChar = function(buffer) {\n  // determine how many bytes we have to check at the end of this buffer\n  var i = (buffer.length >= 3) ? 3 : buffer.length;\n\n  // Figure out if one of the last i bytes of our buffer announces an\n  // incomplete char.\n  for (; i > 0; i--) {\n    var c = buffer[buffer.length - i];\n\n    // See http://en.wikipedia.org/wiki/UTF-8#Description\n\n    // 110XXXXX\n    if (i == 1 && c >> 5 == 0x06) {\n      this.charLength = 2;\n      break;\n    }\n\n    // 1110XXXX\n    if (i <= 2 && c >> 4 == 0x0E) {\n      this.charLength = 3;\n      break;\n    }\n\n    // 11110XXX\n    if (i <= 3 && c >> 3 == 0x1E) {\n      this.charLength = 4;\n      break;\n    }\n  }\n  this.charReceived = i;\n};\n\nStringDecoder.prototype.end = function(buffer) {\n  var res = '';\n  if (buffer && buffer.length)\n    res = this.write(buffer);\n\n  if (this.charReceived) {\n    var cr = this.charReceived;\n    var buf = this.charBuffer;\n    var enc = this.encoding;\n    res += buf.slice(0, cr).toString(enc);\n  }\n\n  return res;\n};\n\nfunction passThroughWrite(buffer) {\n  return buffer.toString(this.encoding);\n}\n\nfunction utf16DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 2;\n  this.charLength = this.charReceived ? 2 : 0;\n}\n\nfunction base64DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 3;\n  this.charLength = this.charReceived ? 3 : 0;\n}\n","import {generateSchema} from \"./indexSchemaCreator\";\nimport { has, isString, difference, find } from \"lodash/fp\";\nimport { Buffer } from \"safe-buffer\";\nimport {StringDecoder} from \"string_decoder\";\nimport {getType} from \"../types\";\nimport { isSomething } from \"../common\";\n\nexport const BUFFER_MAX_BYTES = 524288; // 0.5Mb\n\nexport const CONTINUE_READING_RECORDS = \"CONTINUE_READING\";\nexport const READ_REMAINING_TEXT = \"READ_REMAINING\";\nexport const CANCEL_READ = \"CANCEL\";\n\nexport const getIndexWriter = (hierarchy, indexNode, readableStream, writableStream, end) => {\n    const schema = generateSchema(hierarchy, indexNode);\n\n    return ({\n        read: read(readableStream, schema),\n        updateIndex: updateIndex(readableStream, writableStream, schema, end)\n    });\n};\n\nexport const getIndexReader = (hierarchy, indexNode, readableStream) => \n    read(\n        readableStream, \n        generateSchema(hierarchy, indexNode)\n    );\n\nconst updateIndex = (readableStream, writableStream, schema) => async (itemsToWrite, keysToRemove) => {\n    const write = newOutputWriter(BUFFER_MAX_BYTES, writableStream);\n    const writtenItems = []; \n    await read(readableStream, schema)(\n        async indexedItem => {\n            const updated = find(i => indexedItem.key === i.key)(itemsToWrite);\n            const removed = find(k => indexedItem.key === k)(keysToRemove);\n            \n            if(isSomething(removed)) \n                return CONTINUE_READING_RECORDS;\n\n            if(isSomething(updated)) {\n                const serializedItem =  serializeItem(schema, updated);\n                await write(serializedItem);\n                writtenItems.push(updated);\n            } else {\n                await write(\n                    serializeItem(schema, indexedItem)\n                );\n            } \n\n            return CONTINUE_READING_RECORDS;\n\n        },\n        async text => await write(text)\n    );\n\n    if(writtenItems.length !== itemsToWrite.length) {\n        const toAdd = difference(itemsToWrite, writtenItems);\n        for(let added of toAdd) {\n            await write(\n                serializeItem(schema, added)\n            );\n        }\n    } else if(writtenItems.length === 0) {\n        // potentially are no records\n        await write(\"\");\n    }\n\n    await write();\n    await writableStream.end();\n};\n\nconst read = (readableStream, schema) => async (onGetItem, onGetText) => {\n    const readInput = newInputReader(readableStream);\n    let text = await readInput();\n    let status = CONTINUE_READING_RECORDS;\n    while(text.length > 0) {\n\n        if(status === READ_REMAINING_TEXT) {\n            await onGetText(text);\n            continue;\n        }\n\n        if(status === CANCEL_READ) {\n            return;\n        }\n\n        let rowText = \"\";\n        let currentCharIndex=0;\n        for(let currentChar of text) {\n            rowText += currentChar;\n            if(currentChar === \"\\r\") {\n                status = await onGetItem(\n                    deserializeRow(schema, rowText)\n                );\n                rowText = \"\";\n                if(status === READ_REMAINING_TEXT) {\n                    break;\n                }\n            }\n            currentCharIndex++;\n        }\n\n        if(currentCharIndex < text.length -1) {\n            await onGetText(text.substring(currentCharIndex + 1));\n        }\n\n        text = await readInput();\n    }\n\n    await readableStream.destroy();\n\n};\n\nconst newOutputWriter = (flushBoundary, writableStream) => {\n    \n    let currentBuffer = null;\n\n    return async (text) => {\n\n        if(isString(text) && currentBuffer === null)\n            currentBuffer = Buffer.from(text, \"utf8\");\n        else if(isString(text))\n            currentBuffer = Buffer.concat([\n                currentBuffer,\n                Buffer.from(text, \"utf8\")\n            ]);\n        \n        if(currentBuffer !== null &&\n            (currentBuffer.length > flushBoundary\n             || !isString(text))) {\n\n            await writableStream.write(currentBuffer);\n            currentBuffer = null;\n        }\n    }\n};\n\nconst newInputReader = (readableStream) => {\n\n    const decoder = new StringDecoder('utf8');\n    let remainingBytes = [];\n\n    return async () => {\n\n        let nextBytesBuffer = await readableStream.read(BUFFER_MAX_BYTES);\n        const remainingBuffer = Buffer.from(remainingBytes);\n\n        if(!nextBytesBuffer) nextBytesBuffer = Buffer.from([]);\n\n        const moreToRead = nextBytesBuffer.length === BUFFER_MAX_BYTES;\n\n        const buffer = Buffer.concat(\n            [remainingBuffer, nextBytesBuffer],\n            remainingBuffer.length + nextBytesBuffer.length);\n\n        const text = decoder.write(buffer);\n        remainingBytes = decoder.end(buffer);\n\n        if(!moreToRead && remainingBytes.length > 0) {\n            // if for any reason, we have remaining bytes at the end\n            // of the stream, just discard - dont see why this should\n            // ever happen, but if it does, it could cause a stack overflow\n            remainingBytes = [];\n        }\n\n        return text;\n    };\n};\n\nconst deserializeRow = (schema, rowText) => {\n    let currentPropIndex = 0;\n    let currentCharIndex = 0;\n    let currentValueText = \"\";\n    let isEscaped = false;\n    const item = {};\n\n    const setCurrentProp = () => {\n        const currentProp = schema[currentPropIndex];\n        const type = getType(currentProp.type);\n        const value = currentValueText === \"\"\n                      ? type.getDefaultValue()\n                      : type.safeParseValue(\n                          currentValueText);\n        item[currentProp.name] = value;\n    };\n    \n    while(currentPropIndex < schema.length) {\n\n        if(currentCharIndex < rowText.length) {\n            const currentChar = rowText[currentCharIndex];\n            if(isEscaped) {\n                if(currentChar === \"r\") {\n                    currentValueText += \"\\r\";\n                } else {\n                    currentValueText += currentChar;\n                }\n                isEscaped = false;\n            } else {\n                if(currentChar === \",\") {\n                    setCurrentProp();\n                    currentValueText = \"\";\n                    currentPropIndex++;\n                } else if(currentChar === \"\\\\\") {\n                    isEscaped = true;\n                } else {\n                    currentValueText += currentChar;\n                }\n            }\n            currentCharIndex++; \n        } else {\n            currentValueText = \"\";\n            setCurrentProp();\n            currentPropIndex++;\n        }\n    }\n\n    return item;\n};\n\nexport const serializeItem = (schema, item)  => {\n\n    let rowText = \"\"\n\n    for(let prop of schema) {\n        const type = getType(prop.type);\n        const value = has(prop.name)(item)\n                      ? item[prop.name]\n                      : type.getDefaultValue()\n        \n        const valStr = type.stringify(value);\n\n        for(let i = 0; i < valStr.length; i++) {\n            const currentChar = valStr[i];\n            if(currentChar === \",\" \n               || currentChar === \"\\r\" \n               || currentChar === \"\\\\\") {\n                rowText += \"\\\\\";\n            }\n\n            if(currentChar === \"\\r\") {\n                rowText += \"r\";\n            } else {\n                rowText += currentChar;\n            }\n        }\n\n        rowText += \",\";\n    }\n\n    rowText += \"\\r\";\n    return rowText;\n};","import lunr from 'lunr';\nimport {promiseReadableStream} from \"./promiseReadableStream\";\nimport { createIndexFile } from './sharding';\nimport { generateSchema } from './indexSchemaCreator';\nimport { getIndexReader, CONTINUE_READING_RECORDS } from './serializer';\n\nexport const readIndex = async (hierarchy, datastore, index, indexedDataKey) => {\n  const records = [];\n  const doRead = iterateIndex(\n        async item => {\n      records.push(item);\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => records\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\nexport const searchIndex = async (hierarchy, datastore, index, indexedDataKey, searchPhrase) => {\n  const records = [];\n  const schema = generateSchema(hierarchy, index);\n  const doRead = iterateIndex(\n        async item => {\n      const idx = lunr(function () {\n        this.ref('key');\n        for (const field of schema) {\n          this.field(field.name);\n        }\n        this.add(item);\n      });\n      const searchResults = idx.search(searchPhrase);\n      if (searchResults.length === 1) {\n        item._searchResult = searchResults[0];\n        records.push(item);\n      }\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => records\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\nexport const iterateIndex = (onGetItem, getFinalResult) => async (hierarchy, datastore, index, indexedDataKey) => {\n  try {\n    const readableStream = promiseReadableStream(\n        await datastore.readableFileStream(indexedDataKey)\n    );\n\n    const read = getIndexReader(hierarchy, index, readableStream);\n    await read(onGetItem);\n    return getFinalResult();\n  } catch (e) {\n    if (await datastore.exists(indexedDataKey)) {\n      throw e;\n    } else {\n      await createIndexFile(\n        datastore,\n        indexedDataKey,\n        index,\n      );\n    }\n    return [];\n  }\n};\n","import { getRecordInfo } from \"../recordApi/recordInfo\";\nimport { \n    getParentKey, getLastPartInKey\n} from \"../templateApi/hierarchy\";\nimport { keySep } from \"../common\";\n\nexport const getIndexDir = (hierarchy, indexKey) => {\n\n    const parentKey = getParentKey(indexKey);\n\n    if(parentKey === \"\") return indexKey;\n    if(parentKey === keySep) return indexKey;\n\n    const recordInfo = getRecordInfo(\n        hierarchy, \n        parentKey);\n        \n    return recordInfo.child(\n        getLastPartInKey(indexKey));\n}","import { flatten, merge } from 'lodash/fp';\nimport {\n  safeKey, apiWrapper, $,\n  events, isNonEmptyString,\n} from '../common';\nimport { readIndex, searchIndex } from '../indexing/read';\nimport {\n  getUnshardedIndexDataKey,\n  getShardKeysInRange,\n} from '../indexing/sharding';\nimport {\n  getExactNodeForKey, isIndex,\n  isShardedIndex,\n} from '../templateApi/hierarchy';\nimport { permission } from '../authApi/permissions';\nimport { getIndexDir } from \"./getIndexDir\";\n\nexport const listItems = app => async (indexKey, options) => {\n  indexKey = safeKey(indexKey);\n  return apiWrapper(\n    app,\n    events.indexApi.listItems,\n    permission.readIndex.isAuthorized(indexKey),\n    { indexKey, options },\n    _listItems, app, indexKey, options,\n  );\n}\n\nconst defaultOptions = { rangeStartParams: null, rangeEndParams: null, searchPhrase: null };\n\nconst _listItems = async (app, indexKey, options = defaultOptions) => {\n  const { searchPhrase, rangeStartParams, rangeEndParams } = $({}, [\n    merge(options),\n    merge(defaultOptions),\n  ]);\n\n  const getItems = async indexedDataKey => (isNonEmptyString(searchPhrase)\n    ? await searchIndex(\n      app.hierarchy,\n      app.datastore,\n      indexNode,\n      indexedDataKey,\n      searchPhrase,\n    )\n    : await readIndex(\n      app.hierarchy,\n      app.datastore,\n      indexNode,\n      indexedDataKey,\n    ));\n\n  indexKey = safeKey(indexKey);\n  const indexNode = getExactNodeForKey(app.hierarchy)(indexKey);\n  const indexDir = getIndexDir(app.hierarchy, indexKey);\n\n  if (!isIndex(indexNode)) { throw new Error('supplied key is not an index'); }\n\n  if (isShardedIndex(indexNode)) {\n    const shardKeys = await getShardKeysInRange(\n      app, indexNode, indexDir, rangeStartParams, rangeEndParams,\n    );\n    const items = [];\n    for (const k of shardKeys) {\n      items.push(await getItems(k));\n    }\n    return flatten(items);\n  }\n  return await getItems(\n    getUnshardedIndexDataKey(indexDir),\n  );\n};\n","import { map, isString, has, some } from 'lodash/fp';\nimport {\n  getExactNodeForKey,\n  findField, getNode, isGlobalIndex,\n} from '../templateApi/hierarchy';\nimport { listItems } from '../indexApi/listItems';\nimport {\n  $, apiWrapperSync, events, safeKey\n} from '../common';\nimport { getIndexKey_BasedOnDecendant } from '../indexing/sharding';\nimport { permission } from '../authApi/permissions';\n\nexport const getContext = app => recordKey => {\n  recordKey = safeKey(recordKey);\n  return  apiWrapperSync(\n    app,\n    events.recordApi.getContext,\n    permission.readRecord.isAuthorized(recordKey),\n    { recordKey },\n    _getContext, app, recordKey,\n  );\n}\n\nexport const _getContext = (app, recordKey) => {\n  recordKey = safeKey(recordKey);\n  const recordNode = getExactNodeForKey(app.hierarchy)(recordKey);\n\n  const cachedReferenceIndexes = {};\n\n  const lazyLoadReferenceIndex = async (typeOptions) => {\n    if (!has(typeOptions.indexNodeKey)(cachedReferenceIndexes)) {\n      cachedReferenceIndexes[typeOptions.indexNodeKey] = {\n        typeOptions,\n        data: await readReferenceIndex(\n          app, recordKey, typeOptions,\n        ),\n      };\n    }\n\n    return cachedReferenceIndexes[typeOptions.indexNodeKey];\n  };\n\n  const getTypeOptions = typeOptions_or_fieldName => (isString(typeOptions_or_fieldName)\n    ? findField(recordNode, typeOptions_or_fieldName)\n      .typeOptions\n    : typeOptions_or_fieldName);\n\n  return {\n    referenceExists: async (typeOptions_or_fieldName, key) => {\n      const typeOptions = getTypeOptions(typeOptions_or_fieldName);\n      const { data } = await lazyLoadReferenceIndex(typeOptions);\n      return some(i => i.key === key)(data);\n    },\n    referenceOptions: async (typeOptions_or_fieldName) => {\n      const typeOptions = getTypeOptions(typeOptions_or_fieldName);\n      const { data } = await lazyLoadReferenceIndex(typeOptions);\n      return data;\n    },\n    recordNode,\n  };\n};\n\nconst readReferenceIndex = async (app, recordKey, typeOptions) => {\n  const indexNode = getNode(app.hierarchy, typeOptions.indexNodeKey);\n  const indexKey = isGlobalIndex(indexNode)\n    ? indexNode.nodeKey()\n    : getIndexKey_BasedOnDecendant(\n      recordKey, indexNode,\n    );\n\n  const items = await listItems(app)(indexKey);\n  return $(items, [\n    map(i => ({\n      key: i.key,\n      value: i[typeOptions.displayValue],\n    })),\n  ]);\n};\n","import {\n  map, reduce, filter,\n  isEmpty, flatten, each,\n} from 'lodash/fp';\nimport { compileExpression } from '@nx-js/compiler-util';\nimport _ from 'lodash';\nimport { getExactNodeForKey } from '../templateApi/hierarchy';\nimport { validateFieldParse, validateTypeConstraints } from '../types';\nimport { $, isNothing, isNonEmptyString } from '../common';\nimport { _getContext } from './getContext';\n\nconst fieldParseError = (fieldName, value) => ({\n  fields: [fieldName],\n  message: `Could not parse field ${fieldName}:${value}`,\n});\n\nconst validateAllFieldParse = (record, recordNode) => $(recordNode.fields, [\n  map(f => ({ name: f.name, parseResult: validateFieldParse(f, record) })),\n  reduce((errors, f) => {\n    if (f.parseResult.success) return errors;\n    errors.push(\n      fieldParseError(f.name, f.parseResult.value),\n    );\n    return errors;\n  }, []),\n]);\n\nconst validateAllTypeConstraints = async (record, recordNode, context) => {\n  const errors = [];\n  for (const field of recordNode.fields) {\n    $(await validateTypeConstraints(field, record, context), [\n      filter(isNonEmptyString),\n      map(m => ({ message: m, fields: [field.name] })),\n      each(e => errors.push(e)),\n    ]);\n  }\n  return errors;\n};\n\nconst runRecordValidationRules = (record, recordNode) => {\n  const runValidationRule = (rule) => {\n    const isValid = compileExpression(rule.expressionWhenValid);\n    const expressionContext = { record, _ };\n    return (isValid(expressionContext)\n      ? { valid: true }\n      : ({\n        valid: false,\n        fields: rule.invalidFields,\n        message: rule.messageWhenInvalid,\n      }));\n  };\n\n  return $(recordNode.validationRules, [\n    map(runValidationRule),\n    flatten,\n    filter(r => r.valid === false),\n    map(r => ({ fields: r.fields, message: r.message })),\n  ]);\n};\n\nexport const validate = app => async (record, context) => {\n  context = isNothing(context)\n    ? _getContext(app, record.key)\n    : context;\n\n  const recordNode = getExactNodeForKey(app.hierarchy)(record.key);\n  const fieldParseFails = validateAllFieldParse(record, recordNode);\n\n  // non parsing would cause further issues - exit here\n  if (!isEmpty(fieldParseFails)) { return ({ isValid: false, errors: fieldParseFails }); }\n\n  const recordValidationRuleFails = runRecordValidationRules(record, recordNode);\n  const typeContraintFails = await validateAllTypeConstraints(record, recordNode, context);\n\n  if (isEmpty(fieldParseFails)\n       && isEmpty(recordValidationRuleFails)\n       && isEmpty(typeContraintFails)) {\n    return ({ isValid: true, errors: [] });\n  }\n\n  return ({\n    isValid: false,\n    errors: _.union(fieldParseFails, typeContraintFails, recordValidationRuleFails),\n  });\n};\n","import { filter } from 'lodash/fp';\nimport {\n  getFlattenedHierarchy,\n  isCollectionRecord,\n  isRoot,\n} from '../templateApi/hierarchy';\nimport { $, allTrue, joinKey } from '../common';\n\nconst ensureCollectionIsInitialised = async (datastore, node, dir) => {\n  if (!await datastore.exists(dir)) {\n    await datastore.createFolder(dir);\n    await datastore.createFolder(joinKey(dir, node.nodeId));\n  }\n};\n\nexport const initialiseRootCollections = async (datastore, hierarchy) => {\n  const rootCollectionRecord = allTrue(\n    n => isRoot(n.parent()),\n    isCollectionRecord,\n  );\n\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n\n  const collectionRecords = $(flathierarchy, [\n    filter(rootCollectionRecord),\n  ]);\n\n  for (const col of collectionRecords) {\n    await ensureCollectionIsInitialised(\n      datastore,\n      col,\n      col.collectionPathRegx()\n    );\n  }\n};\n\nexport const initialiseChildCollections = async (app, recordInfo) => {\n  const childCollectionRecords = $(recordInfo.recordNode, [\n    n => n.children,\n    filter(isCollectionRecord),\n  ]);\n\n  for (const child of childCollectionRecords) {\n    await ensureCollectionIsInitialised(\n      app.datastore,\n      child,\n      recordInfo.child(child.collectionName),\n    );\n  }\n};\n","import {\n  joinKey, keySep, getHashCode,\n} from '../common';\nimport { getLastPartInKey } from '../templateApi/hierarchy';\n\nexport const TRANSACTIONS_FOLDER = `${keySep}.transactions`;\nexport const LOCK_FILENAME = 'lock';\nexport const LOCK_FILE_KEY = joinKey(\n  TRANSACTIONS_FOLDER, LOCK_FILENAME,\n);\nexport const idSep = '$';\n\nconst isOfType = typ => trans => trans.transactionType === typ;\n\nexport const CREATE_RECORD_TRANSACTION = 'create';\nexport const UPDATE_RECORD_TRANSACTION = 'update';\nexport const DELETE_RECORD_TRANSACTION = 'delete';\nexport const BUILD_INDEX_TRANSACTION = 'build';\n\nexport const isUpdate = isOfType(UPDATE_RECORD_TRANSACTION);\nexport const isDelete = isOfType(DELETE_RECORD_TRANSACTION);\nexport const isCreate = isOfType(CREATE_RECORD_TRANSACTION);\nexport const isBuildIndex = isOfType(BUILD_INDEX_TRANSACTION);\n\nexport const keyToFolderName = nodeKey => getHashCode(nodeKey);\n\nexport const getTransactionId = (recordId, transactionType, uniqueId) => \n  `${recordId}${idSep}${transactionType}${idSep}${uniqueId}`;\n\nexport const buildIndexFolder = '.BUILD-';\nexport const nodeKeyHashFromBuildFolder = folder => folder.replace(buildIndexFolder, '');\n\nexport const isBuildIndexFolder = key => getLastPartInKey(key).startsWith(buildIndexFolder);\n\nexport const IndexNodeKeyFolder = indexNodeKey => joinKey(\n  TRANSACTIONS_FOLDER,\n  buildIndexFolder + keyToFolderName(indexNodeKey),\n);\n\nexport const IndexNodeKeyBatchFolder = (indexNodeKey, count) => \n  joinKey(IndexNodeKeyFolder(indexNodeKey), Math.floor(count / BUILDINDEX_BATCH_COUNT).toString());\n\nexport const IndexShardKeyFolder = (indexNodeKey, indexShardKey) => \n  joinKey(IndexNodeKeyFolder(indexNodeKey), indexShardKey);\n\nexport const BUILDINDEX_BATCH_COUNT = 1000;\nexport const timeoutMilliseconds = 30 * 1000; // 30 secs\nexport const maxLockRetries = 1;\n","import { generate } from 'shortid';\nimport { joinKey } from '../common';\nimport { getLastPartInKey } from '../templateApi/hierarchy';\nimport {\n  IndexNodeKeyFolder, BUILDINDEX_BATCH_COUNT,\n  IndexNodeKeyBatchFolder, TRANSACTIONS_FOLDER, getTransactionId, CREATE_RECORD_TRANSACTION, UPDATE_RECORD_TRANSACTION,\n  DELETE_RECORD_TRANSACTION, BUILD_INDEX_TRANSACTION,\n} from './transactionsCommon';\n\n\nexport const transactionForCreateRecord = async (app, record) => await transaction(\n  app.datastore, CREATE_RECORD_TRANSACTION,\n  record.key, { record },\n  getTransactionKey_Records,\n);\n\nexport const transactionForUpdateRecord = async (app, oldRecord, newRecord) => await transaction(\n  app.datastore, UPDATE_RECORD_TRANSACTION,\n  newRecord.key, { oldRecord, record: newRecord },\n  getTransactionKey_Records,\n);\n\nexport const transactionForDeleteRecord = async (app, record) => await transaction(\n  app.datastore, DELETE_RECORD_TRANSACTION,\n  record.key, { record },\n  getTransactionKey_Records,\n);\n\nexport const transactionForBuildIndex = async (app, indexNodeKey, recordKey, count) => {\n  const transactionFolder = IndexNodeKeyBatchFolder(indexNodeKey, count);\n  if (count % BUILDINDEX_BATCH_COUNT === 0) {\n    await app.datastore.createFolder(transactionFolder);\n  }\n\n  return await transaction(\n    app.datastore, BUILD_INDEX_TRANSACTION,\n    recordKey, { recordKey },\n    id => joinKey(transactionFolder, id),\n  );\n};\n\nexport const createBuildIndexFolder = async (datastore, indexNodeKey) => await datastore.createFolder(\n  IndexNodeKeyFolder(indexNodeKey),\n);\n\nconst getTransactionKey_Records = id => joinKey(TRANSACTIONS_FOLDER, id);\n\nconst transaction = async (datastore, transactionType, recordKey, data, getTransactionKey) => {\n  const recordId = getLastPartInKey(recordKey);\n  const uniqueId = generate();\n  const id = getTransactionId(\n    recordId, transactionType, uniqueId,\n  );\n\n  const key = getTransactionKey(id);\n\n  const trans = {\n    transactionType,\n    recordKey,\n    ...data,\n    id,\n  };\n\n  await datastore.createJson(\n    key, trans,\n  );\n\n  return trans;\n};\n","import { isShardedIndex } from '../templateApi/hierarchy';\nimport { joinKey } from '../common';\nimport { getShardMapKey, getUnshardedIndexDataKey, createIndexFile } from './sharding';\n\nexport const initialiseIndex = async (datastore, dir, index) => {\n  const indexDir = joinKey(dir, index.name);\n\n  await datastore.createFolder(indexDir);\n\n  if (isShardedIndex(index)) {\n    await datastore.createFile(\n      getShardMapKey(indexDir),\n      '[]',\n    );\n  } else {\n    await createIndexFile(\n      datastore,\n      getUnshardedIndexDataKey(indexDir),\n      index,\n    );\n  }\n};\n","import {\n  cloneDeep, take, takeRight,\n  flatten, map, filter\n} from 'lodash/fp';\nimport { initialiseChildCollections } from '../collectionApi/initialise';\nimport { validate } from './validate';\nimport { _loadFromInfo } from './load';\nimport {\n  apiWrapper, events, $, joinKey,\n} from '../common';\nimport {\n  getFlattenedHierarchy, isRecord, getNode, \n  fieldReversesReferenceToNode,\n} from '../templateApi/hierarchy';\nimport {\n  transactionForCreateRecord,\n  transactionForUpdateRecord,\n} from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { initialiseIndex } from '../indexing/initialiseIndex';\nimport { BadRequestError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const save = app => async (record, context) => apiWrapper(\n  app,\n  events.recordApi.save,\n  record.isNew\n    ? permission.createRecord.isAuthorized(record.key)\n    : permission.updateRecord.isAuthorized(record.key), { record },\n  _save, app, record, context, false,\n);\n\n\nexport const _save = async (app, record, context, skipValidation = false) => {\n  const recordClone = cloneDeep(record);\n  if (!skipValidation) {\n    const validationResult = await validate(app)(recordClone, context);\n    if (!validationResult.isValid) {\n      await app.publish(events.recordApi.save.onInvalid, { record, validationResult });\n      throw new BadRequestError(`Save : Record Invalid : ${\n        JSON.stringify(validationResult.errors)}`);\n    }\n  }\n\n  const recordInfo = getRecordInfo(app.hierarchy, record.key);\n  const {\n    recordNode, pathInfo,\n    recordJson, files,\n  } = recordInfo;\n\n  if (recordClone.isNew) {\n    \n    if(!recordNode)\n      throw new Error(\"Cannot find node for \" + record.key);\n\n    const transaction = await transactionForCreateRecord(\n      app, recordClone,\n    );\n    recordClone.transactionId = transaction.id;\n    await createRecordFolderPath(app.datastore, pathInfo);\n    await app.datastore.createFolder(files);\n    await app.datastore.createJson(recordJson, recordClone);\n    await initialiseReverseReferenceIndexes(app, recordInfo);\n    await initialiseAncestorIndexes(app, recordInfo);\n    await initialiseChildCollections(app, recordInfo);\n    await app.publish(events.recordApi.save.onRecordCreated, {\n      record: recordClone,\n    });\n  } else {\n    const oldRecord = await _loadFromInfo(app, recordInfo);\n    const transaction = await transactionForUpdateRecord(\n      app, oldRecord, recordClone,\n    );\n    recordClone.transactionId = transaction.id;\n    await app.datastore.updateJson(\n      recordJson,\n      recordClone,\n    );\n    await app.publish(events.recordApi.save.onRecordUpdated, {\n      old: oldRecord,\n      new: recordClone,\n    });\n  }\n\n  await app.cleanupTransactions();\n\n  const returnedClone = cloneDeep(recordClone);\n  returnedClone.isNew = false;\n  return returnedClone;\n};\n\nconst initialiseAncestorIndexes = async (app, recordInfo) => {\n  for (const index of recordInfo.recordNode.indexes) {\n    const indexKey = recordInfo.child(index.name);\n    if (!await app.datastore.exists(indexKey)) { \n      await initialiseIndex(app.datastore, recordInfo.dir, index); \n    }\n  }\n};\n\nconst initialiseReverseReferenceIndexes = async (app, recordInfo) => {\n\n  const indexNodes = $(fieldsThatReferenceThisRecord(app, recordInfo.recordNode), [\n    map(f => $(f.typeOptions.reverseIndexNodeKeys, [\n      map(n => getNode(\n        app.hierarchy,\n        n,\n      )),\n    ])),\n    flatten,\n  ]);\n\n  for (const indexNode of indexNodes) {\n    await initialiseIndex(\n      app.datastore, recordInfo.dir, indexNode,\n    );\n  }\n};\n\nconst fieldsThatReferenceThisRecord = (app, recordNode) => $(app.hierarchy, [\n  getFlattenedHierarchy,\n  filter(isRecord),\n  map(n => n.fields),\n  flatten,\n  filter(fieldReversesReferenceToNode(recordNode)),\n]);\n\nconst createRecordFolderPath = async (datastore, pathInfo) => {\n  \n  const recursiveCreateFolder = async (subdirs, dirsThatNeedCreated=undefined) => {\n\n    // iterate backwards through directory hierachy\n    // until we get to a folder that exists, then create the rest\n    // e.g \n    // - some/folder/here\n    // - some/folder\n    // - some\n    const thisFolder = joinKey(pathInfo.base, ...subdirs);\n\n    if(await datastore.exists(thisFolder)) {\n\n      let creationFolder = thisFolder;\n      for(let nextDir of (dirsThatNeedCreated || []) ) {\n        creationFolder = joinKey(creationFolder, nextDir);\n        await datastore.createFolder(creationFolder);\n      }\n\n    } else if(!dirsThatNeedCreated || dirsThatNeedCreated.length > 0) {\n\n      dirsThatNeedCreated = !dirsThatNeedCreated\n                          ? []\n                          :dirsThatNeedCreated;\n      \n      await recursiveCreateFolder(\n        take(subdirs.length - 1)(subdirs),\n        [...takeRight(1)(subdirs), ...dirsThatNeedCreated]\n      );\n    }\n  }\n\n  await recursiveCreateFolder(pathInfo.subdirs);\n\n  return joinKey(pathInfo.base, ...pathInfo.subdirs);\n\n}","import {\n  safeKey, apiWrapper,\n  events, joinKey,\n} from '../common';\nimport { _deleteRecord } from '../recordApi/delete';\nimport { getAllIdsIterator } from '../indexing/allIds';\nimport { permission } from '../authApi/permissions';\nimport { getCollectionDir } from \"../recordApi/recordInfo\";\n\nexport const deleteCollection = (app, disableCleanup = false) => async key => apiWrapper(\n  app,\n  events.collectionApi.delete,\n  permission.manageCollection.isAuthorized,\n  { key },\n  _deleteCollection, app, key, disableCleanup,\n);\n\n/*\n  const recordNode = getCollectionNode(app.hierarchy, key);\n\n*/\n\nexport const _deleteCollection = async (app, key, disableCleanup) => {\n  key = safeKey(key);\n  const collectionDir = getCollectionDir(app.hierarchy, key);\n  await deleteRecords(app, key);\n  await deleteCollectionFolder(app, collectionDir);\n  if (!disableCleanup) { await app.cleanupTransactions(); }\n};\n\nconst deleteCollectionFolder = async (app, dir) => \n  await app.datastore.deleteFolder(dir);\n\nconst deleteRecords = async (app, key) => {\n  \n  const iterate = await getAllIdsIterator(app)(key);\n\n  let ids = await iterate();\n  while (!ids.done) {\n    if (ids.result.collectionKey === key) {\n      for (const id of ids.result.ids) {\n        await _deleteRecord(\n          app,\n          joinKey(key, id),\n          true,\n        );\n      }\n    }\n\n    ids = await iterate();\n  }\n};\n","import {\n  safeKey, apiWrapper,\n  events, joinKey,\n} from '../common';\nimport { _load } from './load';\nimport { _deleteCollection } from '../collectionApi/delete';\nimport {\n  getExactNodeForKey\n} from '../templateApi/hierarchy';\nimport { transactionForDeleteRecord } from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { getRecordInfo } from './recordInfo';\n\nexport const deleteRecord = (app, disableCleanup = false) => async key => {\n  key = safeKey(key);\n  return apiWrapper(\n    app,\n    events.recordApi.delete,\n    permission.deleteRecord.isAuthorized(key),\n    { key },\n    _deleteRecord, app, key, disableCleanup,\n  );\n}\n\n// called deleteRecord because delete is a keyword\nexport const _deleteRecord = async (app, key, disableCleanup) => {\n  const recordInfo = getRecordInfo(app.hierarchy, key);\n  key = recordInfo.key;\n  const node = getExactNodeForKey(app.hierarchy)(key);\n\n  const record = await _load(app, key);\n  await transactionForDeleteRecord(app, record);\n\n  for (const collectionRecord of node.children) {\n    const collectionKey = joinKey(\n      key, collectionRecord.collectionName,\n    );\n    await _deleteCollection(app, collectionKey, true);\n  }\n\n  await app.datastore.deleteFolder(recordInfo.dir);\n\n  if (!disableCleanup) { await app.cleanupTransactions(); }\n};\n\n","import {\n  includes, filter,\n  map, some,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { _loadFromInfo } from './load';\nimport {\n  apiWrapper, events, splitKey,\n  $, joinKey, isNothing, tryAwaitOrIgnore,\n} from '../common';\nimport { getExactNodeForKey } from '../templateApi/hierarchy';\nimport { permission } from '../authApi/permissions';\nimport { isLegalFilename } from '../types/file';\nimport { BadRequestError, ForbiddenError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const uploadFile = app => async (recordKey, readableStream, relativeFilePath) => apiWrapper(\n  app,\n  events.recordApi.uploadFile,\n  permission.updateRecord.isAuthorized(recordKey),\n  { recordKey, readableStream, relativeFilePath },\n  _uploadFile, app, recordKey, readableStream, relativeFilePath,\n);\n\nconst _uploadFile = async (app, recordKey, readableStream, relativeFilePath) => {\n  if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); }\n  if (isNothing(relativeFilePath)) { throw new BadRequestError('file path not supplied'); }\n  if (!isLegalFilename(relativeFilePath)) { throw new BadRequestError('Illegal filename'); }\n\n  const recordInfo = getRecordInfo(app.hierarchy, recordKey);\n  const record = await _loadFromInfo(app, recordInfo);\n\n  const fullFilePath = safeGetFullFilePath(\n    recordInfo.dir, relativeFilePath,\n  );\n\n  const tempFilePath = `${fullFilePath}_${generate()}.temp`;\n\n  const outputStream = await app.datastore.writableFileStream(\n    tempFilePath,\n  );\n\n  return new Promise((resolve,reject) => {\n    readableStream.pipe(outputStream);\n    outputStream.on('error', reject);\n    outputStream.on('finish', resolve);\n  })\n  .then(() => app.datastore.getFileSize(tempFilePath))\n  .then(size => {\n    const isExpectedFileSize = checkFileSizeAgainstFields(\n      app, record, relativeFilePath, size\n    );  \n    if (!isExpectedFileSize) { throw new BadRequestError(`Fields for ${relativeFilePath} do not have expected size: ${join(',')(incorrectFields)}`); }  \n\n  })\n  .then(() => tryAwaitOrIgnore(app.datastore.deleteFile, fullFilePath))\n  .then(() => app.datastore.renameFile(tempFilePath, fullFilePath));\n\n};\n\nconst checkFileSizeAgainstFields = (app, record, relativeFilePath, expectedSize) => {\n  const recordNode = getExactNodeForKey(app.hierarchy)(record.key);\n\n  const incorrectFileFields = $(recordNode.fields, [\n    filter(f => f.type === 'file'\n      && record[f.name].relativePath === relativeFilePath\n      && record[f.name].size !== expectedSize),\n    map(f => f.name),\n  ]);\n\n  const incorrectFileArrayFields = $(recordNode.fields, [\n    filter(a => a.type === 'array<file>'\n      && $(record[a.name], [\n        some(f => record[f.name].relativePath === relativeFilePath\n          && record[f.name].size !== expectedSize),\n      ])),\n    map(f => f.name),\n  ]);\n\n  const incorrectFields = [\n    ...incorrectFileFields,\n    ...incorrectFileArrayFields,\n  ];\n\n  if (incorrectFields.length > 0) {\n    return false;\n  }\n\n  return true;\n};\n\nexport const safeGetFullFilePath = (recordDir, relativeFilePath) => {\n  const naughtyUser = () => { throw new ForbiddenError('naughty naughty'); };\n\n  if (relativeFilePath.startsWith('..')) naughtyUser();\n\n  const pathParts = splitKey(relativeFilePath);\n\n  if (includes('..')(pathParts)) naughtyUser();\n\n  const recordKeyParts = splitKey(recordDir);\n\n  const fullPathParts = [\n    ...recordKeyParts,\n    'files',\n    ...filter(p => p !== '.')(pathParts),\n  ];\n\n  return joinKey(fullPathParts);\n};\n","import { apiWrapper, events, isNothing } from '../common';\nimport { permission } from '../authApi/permissions';\nimport { safeGetFullFilePath } from './uploadFile';\nimport { BadRequestError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const downloadFile = app => async (recordKey, relativePath) => apiWrapper(\n  app,\n  events.recordApi.uploadFile,\n  permission.readRecord.isAuthorized(recordKey),\n  { recordKey, relativePath },//remove dupe key 'recordKey' from object\n  _downloadFile, app, recordKey, relativePath,\n); \n\n\nconst _downloadFile = async (app, recordKey, relativePath) => {\n  if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); }\n  if (isNothing(relativePath)) { throw new BadRequestError('file path not supplied'); }\n\n  const {dir} = getRecordInfo(app.hierarchy, recordKey);\n  return await app.datastore.readableFileStream(\n    safeGetFullFilePath(\n      dir, relativePath,\n    ),\n  );\n};\n","import { find, take, union } from 'lodash/fp';\nimport { getFlattenedHierarchy } from '../templateApi/hierarchy';\nimport { $, splitKey, joinKey } from '../common';\nimport { NotFoundError } from '../common/errors';\n\nexport const customId = app => (nodeName, id) => {\n  const node = $(app.hierarchy, [\n    getFlattenedHierarchy,\n    find(n => n.name === nodeName),\n  ]);\n\n  if (!node) throw new NotFoundError(`Cannot find node ${nodeName}`);\n\n  return `${node.nodeId}-${id}`;\n};\n\nexport const setCustomId = app => (record, id) => {\n  record.id = customId(app)(record.type, id);\n\n  const keyParts = splitKey(record.key);\n\n  record.key = $(keyParts, [\n    take(keyParts.length - 1),\n    union([record.id]),\n    joinKey,\n  ]);\n\n  return record;\n};\n","import { getNew, getNewChild } from './getNew';\nimport { load } from './load';\nimport { validate } from './validate';\nimport { getContext } from './getContext';\nimport { save } from './save';\nimport { deleteRecord } from './delete';\nimport { uploadFile } from './uploadFile';\nimport { downloadFile } from './downloadFile';\nimport { customId, setCustomId } from './customId';\n\nconst api = app => ({\n  getNew: getNew(app),\n  getNewChild: getNewChild(app),\n  save: save(app),\n  load: load(app),\n  delete: deleteRecord(app, false),\n  validate: validate(app),\n  getContext: getContext(app),\n  uploadFile: uploadFile(app),\n  downloadFile: downloadFile(app),\n  customId: customId(app),\n  setCustomId: setCustomId(app),\n});\n\n\nexport const getRecordApi = app => api(app);\n\nexport default getRecordApi;\n","import { getNodeForCollectionPath } from '../templateApi/hierarchy';\nimport {\n  isNothing, safeKey, apiWrapperSync, events,\n} from '../common';\nimport { alwaysAuthorized } from '../authApi/permissions';\n\nexport const getAllowedRecordTypes = app => key => apiWrapperSync(\n  app,\n  events.collectionApi.getAllowedRecordTypes,\n  alwaysAuthorized,\n  { key },\n  _getAllowedRecordTypes, app, key,\n);\n\nconst _getAllowedRecordTypes = (app, key) => {\n  key = safeKey(key);\n  const node = getNodeForCollectionPath(app.hierarchy)(key);\n  return isNothing(node) ? [] : [node.name];\n};\n","import { getAllIdsIterator } from '../indexing/allIds';\nimport { getAllowedRecordTypes } from './getAllowedRecordTypes';\nimport { deleteCollection } from './delete';\n\nexport const getCollectionApi = app => ({\n  getAllowedRecordTypes: getAllowedRecordTypes(app),\n  getAllIdsIterator: getAllIdsIterator(app),\n  delete: deleteCollection(app),\n});\n\nexport default getCollectionApi;\n","import {\n  filter, \n  includes, some,\n} from 'lodash/fp';\nimport { getAllIdsIterator } from '../indexing/allIds';\nimport {\n  getFlattenedHierarchy, getRecordNodeById,\n  getNode, isIndex,\n  isRecord, getAllowedRecordNodesForIndex,\n  fieldReversesReferenceToIndex,\n} from '../templateApi/hierarchy';\nimport {\n  joinKey, apiWrapper, events, $\n} from '../common';\nimport {\n  createBuildIndexFolder,\n  transactionForBuildIndex,\n} from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\n\n\n/** rebuilds an index\n * @param {object} app - the application container\n * @param {string} indexNodeKey - node key of the index, which the index belongs to\n */\nexport const buildIndex = app => async indexNodeKey => apiWrapper(\n  app,\n  events.indexApi.buildIndex,\n  permission.manageIndex.isAuthorized,\n  { indexNodeKey },\n  _buildIndex, app, indexNodeKey,\n);\n\nconst _buildIndex = async (app, indexNodeKey) => {\n  const indexNode = getNode(app.hierarchy, indexNodeKey);\n\n  await createBuildIndexFolder(app.datastore, indexNodeKey);\n\n  if (!isIndex(indexNode)) { throw new BadRequestError('BuildIndex: must supply an indexnode'); }\n\n  if (indexNode.indexType === 'reference') {\n    await buildReverseReferenceIndex(\n      app, indexNode,\n    );\n  } else {\n    await buildHeirarchalIndex(\n      app, indexNode,\n    );\n  }\n\n  await app.cleanupTransactions();\n};\n\nconst buildReverseReferenceIndex = async (app, indexNode) => {\n  // Iterate through all referencING records,\n  // and update referenced index for each record\n  let recordCount = 0;\n  const referencingNodes = $(app.hierarchy, [\n    getFlattenedHierarchy,\n    filter(n => isRecord(n)\n                    && some(fieldReversesReferenceToIndex(indexNode))(n.fields)),\n  ]);\n\n  const createTransactionsForReferencingNode = async (referencingNode) => {\n    const iterateReferencingNodes = await getAllIdsIterator(app)(referencingNode.collectionNodeKey());\n\n    let referencingIdIterator = await iterateReferencingNodes();\n    while (!referencingIdIterator.done) {\n      const { result } = referencingIdIterator;\n      for (const id of result.ids) {\n        const recordKey = joinKey(result.collectionKey, id);\n        await transactionForBuildIndex(app, indexNode.nodeKey(), recordKey, recordCount);\n        recordCount++;\n      }\n      referencingIdIterator = await iterateReferencingNodes();\n    }\n  };\n\n  for (const referencingNode of referencingNodes) {\n    await createTransactionsForReferencingNode(referencingNode);\n  }\n};\n\n/*\nconst getAllowedParentCollectionNodes = (hierarchy, indexNode) => $(getAllowedRecordNodesForIndex(hierarchy, indexNode), [\n  map(n => n.parent()),\n]);\n*/\n\nconst buildHeirarchalIndex = async (app, indexNode) => {\n  let recordCount = 0;\n\n  const createTransactionsForIds = async (collectionKey, ids) => {\n    for (const recordId of ids) {\n      const recordKey = joinKey(collectionKey, recordId);\n\n      const recordNode = getRecordNodeById(\n        app.hierarchy,\n        recordId,\n      );\n\n      if (recordNodeApplies(indexNode)(recordNode)) {\n        await transactionForBuildIndex(\n          app, indexNode.nodeKey(),\n          recordKey, recordCount,\n        );\n        recordCount++;\n      }\n    }\n  };\n\n\n  const collectionRecords = getAllowedRecordNodesForIndex(app.hierarchy, indexNode);\n\n  for (const targetCollectionRecordNode of collectionRecords) {\n    const allIdsIterator = await getAllIdsIterator(app)(targetCollectionRecordNode.collectionNodeKey());\n\n    let allIds = await allIdsIterator();\n    while (allIds.done === false) {\n      await createTransactionsForIds(\n        allIds.result.collectionKey,\n        allIds.result.ids,\n      );\n      allIds = await allIdsIterator();\n    }\n  }\n\n  return recordCount;\n};\n\n// const chooseChildRecordNodeByKey = (collectionNode, recordId) => find(c => recordId.startsWith(c.nodeId))(collectionNode.children);\n\nconst recordNodeApplies = indexNode => recordNode => includes(recordNode.nodeId)(indexNode.allowedRecordNodeIds);\n\n/*\nconst hasApplicableDecendant = (hierarchy, ancestorNode, indexNode) => $(hierarchy, [\n  getFlattenedHierarchy,\n  filter(\n    allTrue(\n      isRecord,\n      isDecendant(ancestorNode),\n      recordNodeApplies(indexNode),\n    ),\n  ),\n]);\n*/\n\n /*\nconst applyAllDecendantRecords = async (app, collection_Key_or_NodeKey,\n  indexNode, indexKey, currentIndexedData,\n  currentIndexedDataKey, recordCount = 0) => {\n  const collectionNode = getCollectionNodeByKeyOrNodeKey(\n    app.hierarchy,\n    collection_Key_or_NodeKey,\n  );\n\n  const allIdsIterator = await getAllIdsIterator(app)(collection_Key_or_NodeKey);\n\n\n  const createTransactionsForIds = async (collectionKey, allIds) => {\n    for (const recordId of allIds) {\n      const recordKey = joinKey(collectionKey, recordId);\n\n      const recordNode = chooseChildRecordNodeByKey(\n        collectionNode,\n        recordId,\n      );\n\n      if (recordNodeApplies(indexNode)(recordNode)) {\n        await transactionForBuildIndex(\n          app, indexNode.nodeKey(),\n          recordKey, recordCount,\n        );\n        recordCount++;\n      }\n\n      if (hasApplicableDecendant(app.hierarchy, recordNode, indexNode)) {\n        for (const childCollectionNode of recordNode.children) {\n          recordCount = await applyAllDecendantRecords(\n            app,\n            joinKey(recordKey, childCollectionNode.collectionName),\n            indexNode, indexKey, currentIndexedData,\n            currentIndexedDataKey, recordCount,\n          );\n        }\n      }\n    }\n  };\n\n  let allIds = await allIdsIterator();\n  while (allIds.done === false) {\n    await createTransactionsForIds(\n      allIds.result.collectionKey,\n      allIds.result.ids,\n    );\n    allIds = await allIdsIterator();\n  }\n\n  return recordCount;\n};\n*/\n\nexport default buildIndex;\n","import { has, isNumber, isUndefined } from 'lodash/fp';\nimport { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  safeKey, apiWrapper,\n  events, isNonEmptyString,\n} from '../common';\nimport { iterateIndex } from '../indexing/read';\nimport {\n  getUnshardedIndexDataKey,\n  getShardKeysInRange,\n} from '../indexing/sharding';\nimport {\n  getExactNodeForKey, isIndex,\n  isShardedIndex,\n} from '../templateApi/hierarchy';\nimport { CONTINUE_READING_RECORDS } from '../indexing/serializer';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\nimport { getIndexDir } from \"./getIndexDir\";\n\nexport const aggregates = app => async (indexKey, rangeStartParams = null, rangeEndParams = null) => apiWrapper(\n  app,\n  events.indexApi.aggregates,\n  permission.readIndex.isAuthorized(indexKey),\n  { indexKey, rangeStartParams, rangeEndParams },\n  _aggregates, app, indexKey, rangeStartParams, rangeEndParams,\n);\n\nconst _aggregates = async (app, indexKey, rangeStartParams, rangeEndParams) => {\n  indexKey = safeKey(indexKey);\n  const indexNode = getExactNodeForKey(app.hierarchy)(indexKey);\n  const indexDir = getIndexDir(app.hierarchy, indexKey);\n\n  if (!isIndex(indexNode)) { throw new BadRequestError('supplied key is not an index'); }\n\n  if (isShardedIndex(indexNode)) {\n    const shardKeys = await getShardKeysInRange(\n      app, indexNode, indexDir, rangeStartParams, rangeEndParams,\n    );\n    let aggregateResult = null;\n    for (const k of shardKeys) {\n      const shardResult = await getAggregates(app.hierarchy, app.datastore, indexNode, k);\n      if (aggregateResult === null) {\n        aggregateResult = shardResult;\n      } else {\n        aggregateResult = mergeShardAggregate(\n          aggregateResult,\n          shardResult,\n        );\n      }\n    }\n    return aggregateResult;\n  }\n  return await getAggregates(\n    app.hierarchy,\n    app.datastore,\n    indexNode,\n    getUnshardedIndexDataKey(indexDir),\n  );\n};\n\nconst mergeShardAggregate = (totals, shard) => {\n  const mergeGrouping = (tot, shr) => {\n    tot.count += shr.count;\n    for (const aggName in tot) {\n      if (aggName === 'count') continue;\n      const totagg = tot[aggName];\n      const shragg = shr[aggName];\n      totagg.sum += shragg.sum;\n      totagg.max = totagg.max > shragg.max\n        ? totagg.max\n        : shragg.max;\n      totagg.min = totagg.min < shragg.min\n        ? totagg.min\n        : shragg.min;\n      totagg.mean = totagg.sum / tot.count;\n    }\n    return tot;\n  };\n\n  for (const aggGroupDef in totals) {\n    for (const grouping in shard[aggGroupDef]) {\n      const groupingTotal = totals[aggGroupDef][grouping];\n      totals[aggGroupDef][grouping] = isUndefined(groupingTotal)\n        ? shard[aggGroupDef][grouping]\n        : mergeGrouping(\n          totals[aggGroupDef][grouping],\n          shard[aggGroupDef][grouping],\n        );\n    }\n  }\n\n  return totals;\n};\n\nconst getAggregates = async (hierarchy, datastore, index, indexedDataKey) => {\n  const aggregateResult = {};\n  const doRead = iterateIndex(\n        async item => {\n      applyItemToAggregateResult(\n        index, aggregateResult, item,\n      );\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => aggregateResult\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\n\nconst applyItemToAggregateResult = (indexNode, result, item) => {\n  const getInitialAggregateResult = () => ({\n    sum: 0, mean: null, max: null, min: null,\n  });\n\n  const applyAggregateResult = (agg, existing, count) => {\n    const value = compileCode(agg.aggregatedValue)({ record: item });\n\n    if (!isNumber(value)) return existing;\n\n    existing.sum += value;\n    existing.max = value > existing.max || existing.max === null\n      ? value\n      : existing.max;\n    existing.min = value < existing.min || existing.min === null\n      ? value\n      : existing.min;\n    existing.mean = existing.sum / count;\n    return existing;\n  };\n\n  for (const aggGroup of indexNode.aggregateGroups) {\n    if (!has(aggGroup.name)(result)) {\n      result[aggGroup.name] = {};\n    }\n\n    const thisGroupResult = result[aggGroup.name];\n\n    if (isNonEmptyString(aggGroup.condition)) {\n      if (!compileExpression(aggGroup.condition)({ record: item })) {\n        continue;\n      }\n    }\n\n    let group = isNonEmptyString(aggGroup.groupBy)\n      ? compileCode(aggGroup.groupBy)({ record: item })\n      : 'all';\n    if (!isNonEmptyString(group)) {\n      group = '(none)';\n    }\n\n    if (!has(group)(thisGroupResult)) {\n      thisGroupResult[group] = { count: 0 };\n      for (const agg of aggGroup.aggregates) {\n        thisGroupResult[group][agg.name] = getInitialAggregateResult();\n      }\n    }\n\n    thisGroupResult[group].count++;\n\n    for (const agg of aggGroup.aggregates) {\n      const existingValues = thisGroupResult[group][agg.name];\n      thisGroupResult[group][agg.name] = applyAggregateResult(\n        agg, existingValues,\n        thisGroupResult[group].count,\n      );\n    }\n  }\n};\n","import { buildIndex } from './buildIndex';\nimport { listItems } from './listItems';\nimport { aggregates } from './aggregates';\n\nexport const getIndexApi = app => ({\n  listItems: listItems(app),\n  buildIndex: buildIndex(app),\n  aggregates: aggregates(app),\n});\n\nexport default getIndexApi;\n","import { each, find } from 'lodash';\nimport { map, max, constant } from 'lodash/fp';\nimport {\n  switchCase, defaultCase, joinKey,\n  $, isNothing, isSomething,\n} from '../common';\nimport {\n  isIndex, isRoot, isSingleRecord, isCollectionRecord,\n  isRecord, isaggregateGroup,\n  getFlattenedHierarchy,\n} from './hierarchy';\nimport { all } from '../types';\nimport { BadRequestError } from '../common/errors';\n\nexport const createNodeErrors = {\n  indexCannotBeParent: 'Index template cannot be a parent',\n  allNonRootNodesMustHaveParent: 'Only the root node may have no parent',\n  indexParentMustBeRecordOrRoot: 'An index may only have a record or root as a parent',\n  aggregateParentMustBeAnIndex: 'aggregateGroup parent must be an index',\n};\n\nconst pathRegxMaker = node => () => node.nodeKey().replace(/{id}/g, '[a-zA-Z0-9_-]+');\n\nconst nodeKeyMaker = node => () => switchCase(\n\n  [n => isRecord(n) && !isSingleRecord(n),\n    n => joinKey(\n      node.parent().nodeKey(),\n      node.collectionName,\n      `${n.nodeId}-{id}`,\n    )],\n\n  [isRoot,\n    constant('/')],\n\n  [defaultCase,\n    n => joinKey(node.parent().nodeKey(), n.name)],\n\n)(node);\n\n\nconst validate = parent => (node) => {\n  if (isIndex(node)\n        && isSomething(parent)\n        && !isRoot(parent)\n        && !isRecord(parent)) {\n    throw new BadRequestError(createNodeErrors.indexParentMustBeRecordOrRoot);\n  }\n\n  if (isaggregateGroup(node)\n        && isSomething(parent)\n        && !isIndex(parent)) {\n    throw new BadRequestError(createNodeErrors.aggregateParentMustBeAnIndex);\n  }\n\n  if (isNothing(parent) && !isRoot(node)) { throw new BadRequestError(createNodeErrors.allNonRootNodesMustHaveParent); }\n\n  return node;\n};\n\nconst construct = parent => (node) => {\n  node.nodeKey = nodeKeyMaker(node);\n  node.pathRegx = pathRegxMaker(node);\n  node.parent = constant(parent);\n  node.isRoot = () => isNothing(parent)\n                        && node.name === 'root'\n                        && node.type === 'root';\n  if (isCollectionRecord(node)) {\n    node.collectionNodeKey = () => joinKey(\n      parent.nodeKey(), node.collectionName,\n    );\n    node.collectionPathRegx = () => joinKey(\n      parent.pathRegx(), node.collectionName,\n    );\n  }\n  return node;\n};\n\nconst addToParent = (obj) => {\n  const parent = obj.parent();\n  if (isSomething(parent)) {\n    if (isIndex(obj))\n    // Q: why are indexes not children ?\n    // A: because they cannot have children of their own.\n    { \n      parent.indexes.push(obj); \n    } \n    else if (isaggregateGroup(obj)) \n    { \n      parent.aggregateGroups.push(obj); \n    } else { \n      parent.children.push(obj); \n    }\n\n    if (isRecord(obj)) {\n      const defaultIndex = find(\n        parent.indexes,\n        i => i.name === `${parent.name}_index`,\n      );\n      if (defaultIndex) {\n        defaultIndex.allowedRecordNodeIds.push(obj.nodeId);\n      }\n    }\n  }\n  return obj;\n};\n\nexport const constructNode = (parent, obj) => $(obj, [\n  construct(parent),\n  validate(parent),\n  addToParent,\n]);\n\nconst getNodeId = (parentNode) => {\n  // this case is handled better elsewhere\n  if (!parentNode) return null;\n  const findRoot = n => (isRoot(n) ? n : findRoot(n.parent()));\n  const root = findRoot(parentNode);\n\n  return ($(root, [\n    getFlattenedHierarchy,\n    map(n => n.nodeId),\n    max]) + 1);\n};\n\nexport const constructHierarchy = (node, parent) => {\n  construct(parent)(node);\n  if (node.indexes) {\n    each(node.indexes,\n      child => constructHierarchy(child, node));\n  }\n  if (node.aggregateGroups) {\n    each(node.aggregateGroups,\n      child => constructHierarchy(child, node));\n  }\n  if (node.children && node.children.length > 0) {\n    each(node.children,\n      child => constructHierarchy(child, node));\n  }\n  if (node.fields) {\n    each(node.fields,\n      f => each(f.typeOptions, (val, key) => {\n        const def = all[f.type].optionDefinitions[key];\n        if (!def) {\n          // unknown typeOption\n          delete f.typeOptions[key];\n        } else {\n          f.typeOptions[key] = def.parse(val);\n        }\n      }));\n  }\n  return node;\n};\n\n\nexport const getNewRootLevel = () => construct()({\n  name: 'root',\n  type: 'root',\n  children: [],\n  pathMaps: [],\n  indexes: [],\n  nodeId: 0,\n});\n\nconst _getNewRecordTemplate = (parent, name, createDefaultIndex, isSingle) => {\n  const node = constructNode(parent, {\n    name,\n    type: 'record',\n    fields: [],\n    children: [],\n    validationRules: [],\n    nodeId: getNodeId(parent),\n    indexes: [],\n    estimatedRecordCount: isRecord(parent) ? 500 : 1000000,\n    collectionName: '',\n    isSingle,\n  });\n\n  if (createDefaultIndex) {\n    const defaultIndex = getNewIndexTemplate(parent);\n    defaultIndex.name = `${name}_index`;\n    defaultIndex.allowedRecordNodeIds.push(node.nodeId);\n  }\n\n  return node;\n};\n\nexport const getNewRecordTemplate = (parent, name = '', createDefaultIndex = true) => _getNewRecordTemplate(parent, name, createDefaultIndex, false);\n\nexport const getNewSingleRecordTemplate = parent => _getNewRecordTemplate(parent, '', false, true);\n\nexport const getNewIndexTemplate = (parent, type = 'ancestor') => constructNode(parent, {\n  name: '',\n  type: 'index',\n  map: 'return {...record};',\n  filter: '',\n  indexType: type,\n  getShardName: '',\n  getSortKey: 'record.id',\n  aggregateGroups: [],\n  allowedRecordNodeIds: [],\n  nodeId: getNodeId(parent),\n});\n\nexport const getNewAggregateGroupTemplate = index => constructNode(index, {\n  name: '',\n  type: 'aggregateGroup',\n  groupBy: '',\n  aggregates: [],\n  condition: '',\n  nodeId: getNodeId(index),\n});\n\nexport const getNewAggregateTemplate = (set) => {\n  const aggregatedValue = {\n    name: '',\n    aggregatedValue: '',\n  };\n  set.aggregates.push(aggregatedValue);\n  return aggregatedValue;\n};\n\nexport default {\n  getNewRootLevel,\n  getNewRecordTemplate,\n  getNewIndexTemplate,\n  createNodeErrors,\n  constructHierarchy,\n  getNewAggregateGroupTemplate,\n  getNewAggregateTemplate,\n};\n","import {\n  some, map, filter, keys, includes,\n  countBy, flatten,\n} from 'lodash/fp';\nimport {\n  isSomething, $,\n  isNonEmptyString,\n  isNothingOrEmpty,\n  isNothing,\n} from '../common';\nimport { all, getDefaultOptions } from '../types';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { BadRequestError } from '../common/errors';\n\nexport const fieldErrors = {\n  AddFieldValidationFailed: 'Add field validation: ',\n};\n\nexport const allowedTypes = () => keys(all);\n\nexport const getNewField = type => ({\n  name: '', // how field is referenced internally\n  type,\n  typeOptions: getDefaultOptions(type),\n  label: '', // how field is displayed\n  getInitialValue: 'default', // function that gets value when initially created\n  getUndefinedValue: 'default', // function that gets value when field undefined on record\n});\n\nconst fieldRules = allFields => [\n  makerule('name', 'field name is not set',\n    f => isNonEmptyString(f.name)),\n  makerule('type', 'field type is not set',\n    f => isNonEmptyString(f.type)),\n  makerule('label', 'field label is not set',\n    f => isNonEmptyString(f.label)),\n  makerule('getInitialValue', 'getInitialValue function is not set',\n    f => isNonEmptyString(f.getInitialValue)),\n  makerule('getUndefinedValue', 'getUndefinedValue function is not set',\n    f => isNonEmptyString(f.getUndefinedValue)),\n  makerule('name', 'field name is duplicated',\n    f => isNothingOrEmpty(f.name)\n             || countBy('name')(allFields)[f.name] === 1),\n  makerule('type', 'type is unknown',\n    f => isNothingOrEmpty(f.type)\n             || some(t => f.type === t)(allowedTypes())),\n];\n\nconst typeOptionsRules = (field) => {\n  const type = all[field.type];\n  if (isNothing(type)) return [];\n\n  const def = optName => type.optionDefinitions[optName];\n\n  return $(field.typeOptions, [\n    keys,\n    filter(o => isSomething(def(o))\n                    && isSomething(def(o).isValid)),\n    map(o => makerule(\n      `typeOptions.${o}`,\n      `${def(o).requirementDescription}`,\n      field => def(o).isValid(field.typeOptions[o]),\n    )),\n  ]);\n};\n\nexport const validateField = allFields => (field) => {\n  const everySingleField = includes(field)(allFields) ? allFields : [...allFields, field];\n  return applyRuleSet([...fieldRules(everySingleField), ...typeOptionsRules(field)])(field);\n};\n\nexport const validateAllFields = recordNode => $(recordNode.fields, [\n  map(validateField(recordNode.fields)),\n  flatten,\n]);\n\nexport const addField = (recordTemplate, field) => {\n  if (isNothingOrEmpty(field.label)) {\n    field.label = field.name;\n  }\n  const validationMessages = validateField([...recordTemplate.fields, field])(field);\n  if (validationMessages.length > 0) {\n    const errors = map(m => m.error)(validationMessages);\n    throw new BadRequestError(`${fieldErrors.AddFieldValidationFailed} ${errors.join(', ')}`);\n  }\n  recordTemplate.fields.push(field);\n};\n","import { isNumber, isBoolean, defaultCase } from 'lodash/fp';\nimport { switchCase } from '../common';\n\nexport const getNewRecordValidationRule = (invalidFields,\n  messageWhenInvalid,\n  expressionWhenValid) => ({\n  invalidFields, messageWhenInvalid, expressionWhenValid,\n});\n\nconst getStaticValue = switchCase(\n  [isNumber, v => v.toString()],\n  [isBoolean, v => v.toString()],\n  [defaultCase, v => `'${v}'`],\n);\n\nexport const commonRecordValidationRules = ({\n\n  fieldNotEmpty: fieldName => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} is empty`,\n    `!_.isEmpty(record['${fieldName}'])`,\n  ),\n\n  fieldBetween: (fieldName, min, max) => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} must be between ${min.toString()} and ${max.toString()}`,\n    `record['${fieldName}'] >= ${getStaticValue(min)} &&  record['${fieldName}'] <= ${getStaticValue(max)} `,\n  ),\n\n  fieldGreaterThan: (fieldName, min, max) => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} must be greater than ${min.toString()} and ${max.toString()}`,\n    `record['${fieldName}'] >= ${getStaticValue(min)}  `,\n  ),\n});\n\nexport const addRecordValidationRule = recordNode => rule => recordNode.validationRules.push(rule);\n","\nexport const createTrigger = () => ({\n  actionName: '',\n  eventName: '',\n  // function, has access to event context,\n  // returns object that is used as parameter to action\n  // only used if triggered by event\n  optionsCreator: '',\n  // action runs if true,\n  // has access to event context\n  condition: '',\n});\n\nexport const createAction = () => ({\n  name: '',\n  behaviourSource: '',\n  // name of function in actionSource\n  behaviourName: '',\n  // parameter passed into behaviour.\n  // any other parms passed at runtime e.g.\n  // by trigger, or manually, will be merged into this\n  initialOptions: {},\n});\n","import { flatten, map, isEmpty } from 'lodash/fp';\nimport { compileCode } from '@nx-js/compiler-util';\nimport {\n  isNonEmptyString, \n  executesWithoutException, $, \n} from '../common';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\n\nconst aggregateRules = [\n  makerule('name', 'choose a name for the aggregate',\n    a => isNonEmptyString(a.name)),\n  makerule('aggregatedValue', 'aggregatedValue does not compile',\n    a => isEmpty(a.aggregatedValue)\n            || executesWithoutException(\n              () => compileCode(a.aggregatedValue),\n            )),\n];\n\nexport const validateAggregate = aggregate => applyRuleSet(aggregateRules)(aggregate);\n\nexport const validateAllAggregates = all => $(all, [\n  map(validateAggregate),\n  flatten,\n]);\n","import {\n  filter, union, constant,\n  map, flatten, every, uniqBy,\n  some, includes, isEmpty, has\n} from 'lodash/fp';\nimport { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  $, isSomething, switchCase,\n  anyTrue, isNonEmptyArray, executesWithoutException,\n  isNonEmptyString, defaultCase,\n} from '../common';\nimport {\n  isRecord, isRoot, isaggregateGroup,\n  isIndex, getFlattenedHierarchy,\n} from './hierarchy';\nimport { eventsList } from '../common/events';\nimport { validateAllFields } from './fields';\nimport {\n  applyRuleSet, makerule, stringNotEmpty,\n  validationError,\n} from '../common/validationCommon';\nimport { indexRuleSet } from './indexes';\nimport { validateAllAggregates } from './validateAggregate';\n\nexport const ruleSet = (...sets) => constant(flatten([...sets]));\n\nconst commonRules = [\n  makerule('name', 'node name is not set',\n    node => stringNotEmpty(node.name)),\n  makerule('type', 'node type not recognised',\n    anyTrue(isRecord, isRoot, isIndex, isaggregateGroup)),\n];\n\nconst recordRules = [\n  makerule('fields', 'no fields have been added to the record',\n    node => isNonEmptyArray(node.fields)),\n  makerule('validationRules', \"validation rule is missing a 'messageWhenValid' member\",\n    node => every(r => has('messageWhenInvalid')(r))(node.validationRules)),\n  makerule('validationRules', \"validation rule is missing a 'expressionWhenValid' member\",\n    node => every(r => has('expressionWhenValid')(r))(node.validationRules)),\n];\n\n\nconst aggregateGroupRules = [\n  makerule('condition', 'condition does not compile',\n    a => isEmpty(a.condition)\n             || executesWithoutException(\n               () => compileExpression(a.condition),\n             )),\n];\n\nconst getRuleSet = node => switchCase(\n\n  [isRecord, ruleSet(\n    commonRules,\n    recordRules,\n  )],\n\n  [isIndex, ruleSet(\n    commonRules,\n    indexRuleSet,\n  )],\n\n  [isaggregateGroup, ruleSet(\n    commonRules,\n    aggregateGroupRules,\n  )],\n\n  [defaultCase, ruleSet(commonRules, [])],\n)(node);\n\nexport const validateNode = node => applyRuleSet(getRuleSet(node))(node);\n\nexport const validateAll = (appHierarchy) => {\n  const flattened = getFlattenedHierarchy(\n    appHierarchy,\n  );\n\n  const duplicateNameRule = makerule(\n    'name', 'node names must be unique under shared parent',\n    n => filter(f => f.parent() === n.parent()\n                          && f.name === n.name)(flattened).length === 1,\n  );\n\n  const duplicateNodeKeyErrors = $(flattened, [\n    map(n => applyRuleSet([duplicateNameRule])(n)),\n    filter(isSomething),\n    flatten,\n  ]);\n\n  const fieldErrors = $(flattened, [\n    filter(isRecord),\n    map(validateAllFields),\n    flatten,\n  ]);\n\n  const aggregateErrors = $(flattened, [\n    filter(isaggregateGroup),\n    map(s => validateAllAggregates(\n      s.aggregates,\n    )),\n    flatten,\n  ]);\n\n  return $(flattened, [\n    map(validateNode),\n    flatten,\n    union(duplicateNodeKeyErrors),\n    union(fieldErrors),\n    union(aggregateErrors),\n  ]);\n};\n\nconst actionRules = [\n  makerule('name', 'action must have a name',\n    a => isNonEmptyString(a.name)),\n  makerule('behaviourName', 'must supply a behaviour name to the action',\n    a => isNonEmptyString(a.behaviourName)),\n  makerule('behaviourSource', 'must supply a behaviour source for the action',\n    a => isNonEmptyString(a.behaviourSource)),\n];\n\nconst duplicateActionRule = makerule('', 'action name must be unique', () => {});\n\nconst validateAction = action => applyRuleSet(actionRules)(action);\n\n\nexport const validateActions = (allActions) => {\n  const duplicateActions = $(allActions, [\n    filter(a => filter(a2 => a2.name === a.name)(allActions).length > 1),\n    map(a => validationError(duplicateActionRule, a)),\n  ]);\n\n  const errors = $(allActions, [\n    map(validateAction),\n    flatten,\n    union(duplicateActions),\n    uniqBy('name'),\n  ]);\n\n  return errors;\n};\n\nconst triggerRules = actions => ([\n  makerule('actionName', 'must specify an action',\n    t => isNonEmptyString(t.actionName)),\n  makerule('eventName', 'must specify and event',\n    t => isNonEmptyString(t.eventName)),\n  makerule('actionName', 'specified action not supplied',\n    t => !t.actionName\n             || some(a => a.name === t.actionName)(actions)),\n  makerule('eventName', 'invalid Event Name',\n    t => !t.eventName\n             || includes(t.eventName)(eventsList)),\n  makerule('optionsCreator', 'Options Creator does not compile - check your expression',\n    (t) => {\n      if (!t.optionsCreator) return true;\n      try {\n        compileCode(t.optionsCreator);\n        return true;\n      } catch (_) { return false; }\n    }),\n  makerule('condition', 'Trigger condition does not compile - check your expression',\n    (t) => {\n      if (!t.condition) return true;\n      try {\n        compileExpression(t.condition);\n        return true;\n      } catch (_) { return false; }\n    }),\n]);\n\nexport const validateTrigger = (trigger, allActions) => {\n  const errors = applyRuleSet(triggerRules(allActions))(trigger);\n\n  return errors;\n};\n\nexport const validateTriggers = (triggers, allActions) => $(triggers, [\n  map(t => validateTrigger(t, allActions)),\n  flatten,\n]);\n","import { appDefinitionFile } from '../common';\nimport { constructHierarchy } from './createNodes';\n\nexport const getApplicationDefinition = datastore => async () => {\n  const exists = await datastore.exists(appDefinitionFile);\n\n  if (!exists) throw new Error('Application definition does not exist');\n\n  const appDefinition = await datastore.loadJson(appDefinitionFile);\n  appDefinition.hierarchy = constructHierarchy(\n    appDefinition.hierarchy,\n  );\n  return appDefinition;\n};\n","import { join } from 'lodash';\nimport { permission } from '../authApi/permissions';\nimport { appDefinitionFile } from '../common';\nimport { validateAll } from './validate';\nimport { apiWrapper } from '../common/apiWrapper';\nimport { events } from '../common/events';\n\nexport const saveApplicationHierarchy = app => async hierarchy => apiWrapper(\n  app,\n  events.templateApi.saveApplicationHierarchy,\n  permission.writeTemplates.isAuthorized,\n  { hierarchy },\n  _saveApplicationHierarchy, app.datastore, hierarchy,\n);\n\n\nexport const _saveApplicationHierarchy = async (datastore, hierarchy) => {\n  const validationErrors = await validateAll(hierarchy);\n  if (validationErrors.length > 0) {\n    throw new Error(`Hierarchy is invalid: ${join(\n      validationErrors.map(e => `${e.item.nodeKey ? e.item.nodeKey() : ''} : ${e.error}`),\n      ',',\n    )}`);\n  }\n\n  if (await datastore.exists(appDefinitionFile)) {\n    const appDefinition = await datastore.loadJson(appDefinitionFile);\n    appDefinition.hierarchy = hierarchy;\n    await datastore.updateJson(appDefinitionFile, appDefinition);\n  } else {\n    await datastore.createFolder('/.config');\n    const appDefinition = { actions: [], triggers: [], hierarchy };\n    await datastore.createJson(appDefinitionFile, appDefinition);\n  }\n};\n","import { join } from 'lodash';\nimport { map } from 'lodash/fp';\nimport { appDefinitionFile } from '../common';\nimport { validateTriggers, validateActions } from './validate';\nimport { apiWrapper } from '../common/apiWrapper';\nimport { events } from '../common/events';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\n\nexport const saveActionsAndTriggers = app => async (actions, triggers) => apiWrapper(\n  app,\n  events.templateApi.saveActionsAndTriggers,\n  permission.writeTemplates.isAuthorized,\n  { actions, triggers },\n  _saveActionsAndTriggers, app.datastore, actions, triggers,\n);\n\nexport const _saveActionsAndTriggers = async (datastore, actions, triggers) => {\n  if (await datastore.exists(appDefinitionFile)) {\n    const appDefinition = await datastore.loadJson(appDefinitionFile);\n    appDefinition.actions = actions;\n    appDefinition.triggers = triggers;\n\n    const actionValidErrs = map(e => e.error)(validateActions(actions));\n\n    if (actionValidErrs.length > 0) {\n      throw new BadRequestError(`Actions are invalid: ${join(actionValidErrs, ', ')}`);\n    }\n\n    const triggerValidErrs = map(e => e.error)(validateTriggers(triggers, actions));\n\n    if (triggerValidErrs.length > 0) {\n      throw new BadRequestError(`Triggers are invalid: ${join(triggerValidErrs, ', ')}`);\n    }\n\n    await datastore.updateJson(appDefinitionFile, appDefinition);\n  } else {\n    throw new BadRequestError('Cannot save actions: Application definition does not exist');\n  }\n};\n","\nexport const getBehaviourSources = async (datastore) => {\n    await datastore.loadFile('/.config/behaviourSources.js');\n};\n","import {\n  getNewRootLevel,\n  getNewRecordTemplate, getNewIndexTemplate,\n  createNodeErrors, constructHierarchy,\n  getNewAggregateGroupTemplate, getNewSingleRecordTemplate,\n  getNewAggregateTemplate, constructNode,\n}\n  from './createNodes';\nimport {\n  getNewField, validateField,\n  addField, fieldErrors,\n} from './fields';\nimport {\n  getNewRecordValidationRule, commonRecordValidationRules,\n  addRecordValidationRule,\n} from './recordValidationRules';\nimport { createAction, createTrigger } from './createActions';\nimport {\n  validateTriggers, validateTrigger, validateNode,\n  validateActions, validateAll,\n} from './validate';\nimport { getApplicationDefinition } from './getApplicationDefinition';\nimport { saveApplicationHierarchy } from './saveApplicationHierarchy';\nimport { saveActionsAndTriggers } from './saveActionsAndTriggers';\nimport { all } from '../types';\nimport { getBehaviourSources } from \"./getBehaviourSources\";\n\nconst api = app => ({\n\n  getApplicationDefinition: getApplicationDefinition(app.datastore),\n  saveApplicationHierarchy: saveApplicationHierarchy(app),\n  saveActionsAndTriggers: saveActionsAndTriggers(app),\n  getBehaviourSources: () => getBehaviourSources(app.datastore),\n  getNewRootLevel,\n  constructNode,\n  getNewIndexTemplate,\n  getNewRecordTemplate,\n  getNewField,\n  validateField,\n  addField,\n  fieldErrors,\n  getNewRecordValidationRule,\n  commonRecordValidationRules,\n  addRecordValidationRule,\n  createAction,\n  createTrigger,\n  validateActions,\n  validateTrigger,\n  getNewAggregateGroupTemplate,\n  getNewAggregateTemplate,\n  constructHierarchy,\n  getNewSingleRecordTemplate,\n  allTypes: all,\n  validateNode,\n  validateAll,\n  validateTriggers,\n});\n\n\nexport const getTemplateApi = app => api(app);\n\nexport const errors = createNodeErrors;\n\nexport default getTemplateApi;\n","import { map } from 'lodash/fp';\nimport {\n  USERS_LIST_FILE,\n  stripUserOfSensitiveStuff,\n} from './authCommon';\nimport { $, apiWrapper, events } from '../common';\nimport { permission } from './permissions';\n\nexport const getUsers = app => async () => apiWrapper(\n  app,\n  events.authApi.getUsers,\n  permission.listUsers.isAuthorized,\n  {},\n  _getUsers, app,\n);\n\nexport const _getUsers = async app => $(await app.datastore.loadJson(USERS_LIST_FILE), [\n  map(stripUserOfSensitiveStuff),\n]);\n","import { ACCESS_LEVELS_FILE } from './authCommon';\nimport { apiWrapper, events } from '../common';\nimport { permission } from './permissions';\n\nexport const loadAccessLevels = app => async () => apiWrapper(\n  app,\n  events.authApi.loadAccessLevels,\n  permission.listAccessLevels.isAuthorized,\n  {},\n  _loadAccessLevels, app,\n);\n\nexport const _loadAccessLevels = async app => await app.datastore.loadJson(ACCESS_LEVELS_FILE);\n","import {\n  find, filter, some,\n  map, flatten,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { _getUsers } from './getUsers';\nimport {\n  getUserByName, userAuthFile,\n  parseTemporaryCode,\n} from './authCommon';\nimport { _loadAccessLevels } from './loadAccessLevels';\nimport {\n  isNothingOrEmpty, $, apiWrapper, events,\n} from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nconst dummyHash = '$argon2i$v=19$m=4096,t=3,p=1$UZRo409UYBGjHJS3CV6Uxw$rU84qUqPeORFzKYmYY0ceBLDaPO+JWSH4PfNiKXfIKk';\n\nexport const authenticate = app => async (username, password) => apiWrapper(\n  app,\n  events.authApi.authenticate,\n  alwaysAuthorized,\n  { username, password },\n  _authenticate, app, username, password,\n);\n\nexport const _authenticate = async (app, username, password) => {\n  if (isNothingOrEmpty(username) || isNothingOrEmpty(password)) { return null; }\n\n  const allUsers = await _getUsers(app);\n  let user = getUserByName(\n    allUsers,\n    username,\n  );\n\n  const notAUser = 'not-a-user';\n  // continue with non-user - so time to verify remains consistent\n  // with verification of a valid user\n  if (!user || !user.enabled) { user = notAUser; }\n\n  let userAuth;\n  try {\n    userAuth = await app.datastore.loadJson(\n      userAuthFile(username),\n    );\n  } catch (_) {\n    userAuth = { accessLevels: [], passwordHash: dummyHash };\n  }\n\n  const permissions = await buildUserPermissions(app, user.accessLevels);\n\n  const verified = await app.crypto.verify(\n    userAuth.passwordHash,\n    password,\n  );\n\n  if (user === notAUser) { return null; }\n\n  return verified\n    ? {\n      ...user, permissions, temp: false, isUser: true,\n    }\n    : null;\n};\n\nexport const authenticateTemporaryAccess = app => async (tempAccessCode) => {\n  if (isNothingOrEmpty(tempAccessCode)) { return null; }\n\n  const temp = parseTemporaryCode(tempAccessCode);\n  let user = $(await _getUsers(app), [\n    find(u => u.temporaryAccessId === temp.id),\n  ]);\n\n  const notAUser = 'not-a-user';\n  if (!user || !user.enabled) { user = notAUser; }\n\n  let userAuth;\n  try {\n    userAuth = await app.datastore.loadJson(\n      userAuthFile(user.name),\n    );\n  } catch (e) {\n    userAuth = {\n      temporaryAccessHash: dummyHash,\n      temporaryAccessExpiryEpoch: (await app.getEpochTime() + 10000),\n    };\n  }\n\n  if (userAuth.temporaryAccessExpiryEpoch < await app.getEpochTime()) { user = notAUser; }\n\n  const tempCode = !temp.code ? generate() : temp.code;\n  const verified = await app.crypto.verify(\n    userAuth.temporaryAccessHash,\n    tempCode,\n  );\n\n  if (user === notAUser) { return null; }\n\n  return verified\n    ? {\n      ...user,\n      permissions: [],\n      temp: true,\n      isUser: true,\n    }\n    : null;\n};\n\nexport const buildUserPermissions = async (app, userAccessLevels) => {\n  const allAccessLevels = await _loadAccessLevels(app);\n\n  return $(allAccessLevels.levels, [\n    filter(l => some(ua => l.name === ua)(userAccessLevels)),\n    map(l => l.permissions),\n    flatten,\n  ]);\n};\n","import { generate } from 'shortid';\nimport {\n  tempCodeExpiryLength, USERS_LOCK_FILE,\n  USERS_LIST_FILE, userAuthFile,\n  getUserByName,\n} from './authCommon';\nimport {\n  getLock, isNolock,\n  releaseLock,\n} from '../common/lock';\nimport { apiWrapper, events } from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nexport const createTemporaryAccess = app => async userName => apiWrapper(\n  app,\n  events.authApi.createTemporaryAccess,\n  alwaysAuthorized,\n  { userName },\n  _createTemporaryAccess, app, userName,\n);\n\nexport const _createTemporaryAccess = async (app, userName) => {\n  const tempCode = await getTemporaryCode(app);\n\n  const lock = await getLock(\n    app, USERS_LOCK_FILE, 1000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Unable to create temporary access, could not get lock - try again'); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n\n    const user = getUserByName(users, userName);\n    user.temporaryAccessId = tempCode.temporaryAccessId;\n\n    await app.datastore.updateJson(\n      USERS_LIST_FILE,\n      users,\n    );\n  } finally {\n    await releaseLock(app, lock);\n  }\n\n  const userAuth = await app.datastore.loadJson(\n    userAuthFile(userName),\n  );\n  userAuth.temporaryAccessHash = tempCode.temporaryAccessHash;\n\n  userAuth.temporaryAccessExpiryEpoch = tempCode.temporaryAccessExpiryEpoch;\n\n  await app.datastore.updateJson(\n    userAuthFile(userName),\n    userAuth,\n  );\n\n  return tempCode.tempCode;\n};\n\nexport const getTemporaryCode = async (app) => {\n  const tempCode = generate()\n        + generate()\n        + generate()\n        + generate();\n\n  const tempId = generate();\n\n  return {\n    temporaryAccessHash: await app.crypto.hash(\n      tempCode,\n    ),\n    temporaryAccessExpiryEpoch:\n            (await app.getEpochTime()) + tempCodeExpiryLength,\n    tempCode: `tmp:${tempId}:${tempCode}`,\n    temporaryAccessId: tempId,\n  };\n};\n\nexport const looksLikeTemporaryCode = code => code.startsWith('tmp:');\n","import {\n  map, uniqWith,\n  flatten, filter,\n} from 'lodash/fp';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport {\n  $, insensitiveEquals, apiWrapper, events,\n  isNonEmptyString, all,\n} from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nconst userRules = allUsers => [\n  makerule('name', 'username must be set',\n    u => isNonEmptyString(u.name)),\n  makerule('accessLevels', 'user must have at least one access level',\n    u => u.accessLevels.length > 0),\n  makerule('name', 'username must be unique',\n    u => filter(u2 => insensitiveEquals(u2.name, u.name))(allUsers).length === 1),\n  makerule('accessLevels', 'access levels must only contain stings',\n    u => all(isNonEmptyString)(u.accessLevels)),\n];\n\nexport const validateUser = () => (allusers, user) => applyRuleSet(userRules(allusers))(user);\n\nexport const validateUsers = app => allUsers => apiWrapper(\n  app,\n  events.authApi.validateUsers,\n  alwaysAuthorized,\n  { allUsers },\n  _validateUsers, app, allUsers,\n);\n\nexport const _validateUsers = (app, allUsers) => $(allUsers, [\n  map(l => validateUser(app)(allUsers, l)),\n  flatten,\n  uniqWith((x, y) => x.field === y.field\n                        && x.item === y.item\n                        && x.error === y.error),\n]);\n","import { apiWrapperSync, events } from '../common';\nimport { permission } from './permissions';\n\nexport const getNewUser = app => () => apiWrapperSync(\n  app,\n  events.authApi.getNewUser,\n  permission.createUser.isAuthorized,\n  {},\n  _getNewUser, app,\n);\n\nexport const _getNewUser = () => ({\n  name: '',\n  accessLevels: [],\n  enabled: true,\n  temporaryAccessId: '',\n});\n\nexport const getNewUserAuth = app => () => apiWrapperSync(\n  app,\n  events.authApi.getNewUserAuth,\n  permission.createUser.isAuthorized,\n  {},\n  _getNewUserAuth, app,\n);\n\nexport const _getNewUserAuth = () => ({\n  passwordHash: '',\n  temporaryAccessHash: '',\n  temporaryAccessExpiryEpoch: 0,\n});\n","import { find } from 'lodash/fp';\nimport { userAuthFile, parseTemporaryCode } from './authCommon';\nimport {\n  isSomething, $, apiWrapper, apiWrapperSync, events,\n} from '../common';\nimport { _getUsers } from './getUsers';\nimport { alwaysAuthorized } from './permissions';\n\nexport const isValidPassword = app => password => apiWrapperSync(\n  app,\n  events.authApi.isValidPassword,\n  alwaysAuthorized,\n  { password },\n  _isValidPassword, app, password,\n);\n\nexport const _isValidPassword = (app, password) => scorePassword(password).score > 30;\n\nexport const changeMyPassword = app => async (currentPw, newpassword) => apiWrapper(\n  app,\n  events.authApi.changeMyPassword,\n  alwaysAuthorized,\n  { currentPw, newpassword },\n  _changeMyPassword, app, currentPw, newpassword,\n);\n\nexport const _changeMyPassword = async (app, currentPw, newpassword) => {\n  const existingAuth = await app.datastore.loadJson(\n    userAuthFile(app.user.name),\n  );\n\n  if (isSomething(existingAuth.passwordHash)) {\n    const verified = await app.crypto.verify(\n      existingAuth.passwordHash,\n      currentPw,\n    );\n\n    if (verified) {\n      await await doSet(\n        app, existingAuth,\n        app.user.name, newpassword,\n      );\n      return true;\n    }\n  }\n\n  return false;\n};\n\nexport const setPasswordFromTemporaryCode = app => async (tempCode, newpassword) => apiWrapper(\n  app,\n  events.authApi.setPasswordFromTemporaryCode,\n  alwaysAuthorized,\n  { tempCode, newpassword },\n  _setPasswordFromTemporaryCode, app, tempCode, newpassword,\n);\n\n\nexport const _setPasswordFromTemporaryCode = async (app, tempCode, newpassword) => {\n  const currentTime = await app.getEpochTime();\n\n  const temp = parseTemporaryCode(tempCode);\n\n  const user = $(await _getUsers(app), [\n    find(u => u.temporaryAccessId === temp.id),\n  ]);\n\n  if (!user) { return false; }\n\n  const existingAuth = await app.datastore.loadJson(\n    userAuthFile(user.name),\n  );\n\n  if (isSomething(existingAuth.temporaryAccessHash)\n       && existingAuth.temporaryAccessExpiryEpoch > currentTime) {\n    const verified = await app.crypto.verify(\n      existingAuth.temporaryAccessHash,\n      temp.code,\n    );\n\n    if (verified) {\n      await doSet(\n        app, existingAuth,\n        user.name, newpassword,\n      );\n      return true;\n    }\n  }\n\n  return false;\n};\n\nconst doSet = async (app, auth, username, newpassword) => {\n  auth.temporaryAccessHash = '';\n  auth.temporaryAccessExpiryEpoch = 0;\n  auth.passwordHash = await app.crypto.hash(\n    newpassword,\n  );\n  await app.datastore.updateJson(\n    userAuthFile(username),\n    auth,\n  );\n};\n\nexport const scorePassword = app => password => apiWrapperSync(\n  app,\n  events.authApi.scorePassword,\n  alwaysAuthorized,\n  { password },\n  _scorePassword, password,\n);\n\nexport const _scorePassword = (password) => {\n  // from https://stackoverflow.com/questions/948172/password-strength-meter\n  // thank you https://stackoverflow.com/users/46617/tm-lv\n\n  let score = 0;\n  if (!password) { return score; }\n\n  // award every unique letter until 5 repetitions\n  const letters = new Object();\n  for (let i = 0; i < password.length; i++) {\n    letters[password[i]] = (letters[password[i]] || 0) + 1;\n    score += 5.0 / letters[password[i]];\n  }\n\n  // bonus points for mixing it up\n  const variations = {\n    digits: /\\d/.test(password),\n    lower: /[a-z]/.test(password),\n    upper: /[A-Z]/.test(password),\n    nonWords: /\\W/.test(password),\n  };\n\n  let variationCount = 0;\n  for (const check in variations) {\n    variationCount += (variations[check] == true) ? 1 : 0;\n  }\n  score += (variationCount - 1) * 10;\n\n  const strengthText = score > 80\n    ? 'strong'\n    : score > 60\n      ? 'good'\n      : score >= 30\n        ? 'weak'\n        : 'very weak';\n\n  return {\n    score: parseInt(score),\n    strengthText,\n  };\n};\n","import { join, some } from 'lodash/fp';\nimport { validateUser } from './validateUser';\nimport { getNewUserAuth } from './getNewUser';\nimport {\n  getLock, isNolock, releaseLock, apiWrapper, events,\n  insensitiveEquals, isNonEmptyString,\n} from '../common';\nimport {\n  USERS_LOCK_FILE, stripUserOfSensitiveStuff,\n  USERS_LIST_FILE, userAuthFile,\n} from './authCommon';\nimport { getTemporaryCode } from './createTemporaryAccess';\nimport { isValidPassword } from './setPassword';\nimport { permission } from './permissions';\nimport { BadRequestError } from '../common/errors';\n\nexport const createUser = app => async (user, password = null) => apiWrapper(\n  app,\n  events.authApi.createUser,\n  permission.createUser.isAuthorized,\n  { user, password },\n  _createUser, app, user, password,\n);\n\nexport const _createUser = async (app, user, password = null) => {\n  const lock = await getLock(\n    app, USERS_LOCK_FILE, 1000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Unable to create user, could not get lock - try again'); }\n\n  const users = await app.datastore.loadJson(USERS_LIST_FILE);\n\n  const userErrors = validateUser(app)([...users, user], user);\n  if (userErrors.length > 0) { throw new BadRequestError(`User is invalid. ${join('; ')(userErrors)}`); }\n\n  const { auth, tempCode, temporaryAccessId } = await getAccess(\n    app, password,\n  );\n  user.tempCode = tempCode;\n  user.temporaryAccessId = temporaryAccessId;\n\n  if (some(u => insensitiveEquals(u.name, user.name))(users)) { \n    throw new BadRequestError('User already exists'); \n  }\n\n  users.push(\n    stripUserOfSensitiveStuff(user),\n  );\n\n  await app.datastore.updateJson(\n    USERS_LIST_FILE,\n    users,\n  );\n\n  try {\n    await app.datastore.createJson(\n      userAuthFile(user.name),\n      auth,\n    );\n  } catch (_) {\n    await app.datastore.updateJson(\n      userAuthFile(user.name),\n      auth,\n    );\n  }\n\n  await releaseLock(app, lock);\n\n  return user;\n};\n\nconst getAccess = async (app, password) => {\n  const auth = getNewUserAuth(app)();\n\n  if (isNonEmptyString(password)) {\n    if (isValidPassword(password)) {\n      auth.passwordHash = await app.crypto.hash(password);\n      auth.temporaryAccessHash = '';\n      auth.temporaryAccessId = '';\n      auth.temporaryAccessExpiryEpoch = 0;\n      return { auth };\n    }\n    throw new BadRequestError('Password does not meet requirements');\n  } else {\n    const tempAccess = await getTemporaryCode(app);\n    auth.temporaryAccessHash = tempAccess.temporaryAccessHash;\n    auth.temporaryAccessExpiryEpoch = tempAccess.temporaryAccessExpiryEpoch;\n    auth.passwordHash = '';\n    return ({\n      auth,\n      tempCode: tempAccess.tempCode,\n      temporaryAccessId: tempAccess.temporaryAccessId,\n    });\n  }\n};\n","import {\n  getLock,\n  isNolock, releaseLock,\n} from '../common/lock';\nimport { USERS_LOCK_FILE, USERS_LIST_FILE, getUserByName } from './authCommon';\nimport { apiWrapper, events } from '../common';\nimport { permission } from './permissions';\nimport { NotFoundError } from '../common/errors';\n\nexport const enableUser = app => async username => apiWrapper(\n  app,\n  events.authApi.enableUser,\n  permission.enableDisableUser.isAuthorized,\n  { username },\n  _enableUser, app, username,\n);\n\nexport const disableUser = app => async username => apiWrapper(\n  app,\n  events.authApi.disableUser,\n  permission.enableDisableUser.isAuthorized,\n  { username },\n  _disableUser, app, username,\n);\n\nexport const _enableUser = async (app, username) => await toggleUser(app, username, true);\n\nexport const _disableUser = async (app, username) => await toggleUser(app, username, false);\n\nconst toggleUser = async (app, username, enabled) => {\n  const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0);\n\n  const actionName = enabled ? 'enable' : 'disable';\n\n  if (isNolock(lock)) { throw new Error(`Could not ${actionName} user - cannot get lock`); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n    const user = getUserByName(users, username);\n    if (!user) { throw new NotFoundError(`Could not find user to ${actionName}`); }\n\n    if (user.enabled === !enabled) {\n      user.enabled = enabled;\n      await app.datastore.updateJson(USERS_LIST_FILE, users);\n    }\n  } finally {\n    releaseLock(app, lock);\n  }\n};\n","export const getNewAccessLevel = () => () => ({\n  name: '',\n  permissions: [],\n  default:false\n});\n","import {\n  values, includes, map, concat, isEmpty, uniqWith, some,\n  flatten, filter,\n} from 'lodash/fp';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { permissionTypes } from './authCommon';\nimport {\n  $, isSomething, insensitiveEquals,\n  isNonEmptyString, apiWrapperSync, events,\n} from '../common';\nimport { getNode } from '../templateApi/hierarchy';\nimport { alwaysAuthorized } from './permissions';\n\nconst isAllowedType = t => $(permissionTypes, [\n  values,\n  includes(t),\n]);\n\nconst isRecordOrIndexType = t => some(p => p === t)([\n  permissionTypes.CREATE_RECORD,\n  permissionTypes.UPDATE_RECORD,\n  permissionTypes.DELETE_RECORD,\n  permissionTypes.READ_RECORD,\n  permissionTypes.READ_INDEX,\n  permissionTypes.EXECUTE_ACTION,\n]);\n\n\nconst permissionRules = app => ([\n  makerule('type', 'type must be one of allowed types',\n    p => isAllowedType(p.type)),\n  makerule('nodeKey', 'record and index permissions must include a valid nodeKey',\n    p => (!isRecordOrIndexType(p.type))\n             || isSomething(getNode(app.hierarchy, p.nodeKey))),\n]);\n\nconst applyPermissionRules = app => applyRuleSet(permissionRules(app));\n\nconst accessLevelRules = allLevels => ([\n  makerule('name', 'name must be set',\n    l => isNonEmptyString(l.name)),\n  makerule('name', 'access level names must be unique',\n    l => isEmpty(l.name)\n             || filter(a => insensitiveEquals(l.name, a.name))(allLevels).length === 1),\n]);\n\nconst applyLevelRules = allLevels => applyRuleSet(accessLevelRules(allLevels));\n\nexport const validateAccessLevel = app => (allLevels, level) => {\n  const errs = $(level.permissions, [\n    map(applyPermissionRules(app)),\n    flatten,\n    concat(\n      applyLevelRules(allLevels)(level),\n    ),\n  ]);\n\n  return errs;\n};\n\nexport const validateAccessLevels = app => allLevels => apiWrapperSync(\n  app,\n  events.authApi.validateAccessLevels,\n  alwaysAuthorized,\n  { allLevels },\n  _validateAccessLevels, app, allLevels,\n);\n\nexport const _validateAccessLevels = (app, allLevels) => $(allLevels, [\n  map(l => validateAccessLevel(app)(allLevels, l)),\n  flatten,\n  uniqWith((x, y) => x.field === y.field\n                        && x.item === y.item\n                        && x.error === y.error),\n]);\n","import { join, map } from 'lodash/fp';\nimport {\n  getLock, releaseLock, $,\n  isNolock, apiWrapper, events,\n} from '../common';\nimport {\n  ACCESS_LEVELS_LOCK_FILE,\n  ACCESS_LEVELS_FILE,\n} from './authCommon';\nimport { validateAccessLevels } from './validateAccessLevels';\nimport { permission } from './permissions';\n\nexport const saveAccessLevels = app => async accessLevels => apiWrapper(\n  app,\n  events.authApi.saveAccessLevels,\n  permission.writeAccessLevels.isAuthorized,\n  { accessLevels },\n  _saveAccessLevels, app, accessLevels,\n);\n\nexport const _saveAccessLevels = async (app, accessLevels) => {\n  const validationErrors = validateAccessLevels(app)(accessLevels.levels);\n  if (validationErrors.length > 0) {\n    const errs = $(validationErrors, [\n      map(e => e.error),\n      join(', '),\n    ]);\n    throw new Error(\n      `Access Levels Invalid: ${errs}`,\n    );\n  }\n\n  const lock = await getLock(\n    app, ACCESS_LEVELS_LOCK_FILE, 2000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Could not get lock to save access levels'); }\n\n  try {\n    const existing = await app.datastore.loadJson(ACCESS_LEVELS_FILE);\n    if (existing.version !== accessLevels.version) { throw new Error('Access levels have already been updated, since you loaded'); }\n\n    accessLevels.version++;\n\n    app.datastore.updateJson(ACCESS_LEVELS_FILE, accessLevels);\n  } finally {\n    await releaseLock(app, lock);\n  }\n};\n","import {\n  filter, values, each, keys,\n} from 'lodash/fp';\nimport { permission } from './permissions';\nimport {\n  getFlattenedHierarchy,\n  isIndex, isRecord,\n} from '../templateApi/hierarchy';\nimport { $ } from '../common';\n\nexport const generateFullPermissions = (app) => {\n  const allNodes = getFlattenedHierarchy(app.hierarchy);\n  const accessLevel = { permissions: [] };\n\n  const recordNodes = $(allNodes, [\n    filter(isRecord),\n  ]);\n\n  for (const n of recordNodes) {\n    permission.createRecord.add(n.nodeKey(), accessLevel);\n    permission.updateRecord.add(n.nodeKey(), accessLevel);\n    permission.deleteRecord.add(n.nodeKey(), accessLevel);\n    permission.readRecord.add(n.nodeKey(), accessLevel);\n  }\n\n  const indexNodes = $(allNodes, [\n    filter(isIndex),\n  ]);\n\n  for (const n of indexNodes) {\n    permission.readIndex.add(n.nodeKey(), accessLevel);\n  }\n\n  for (const a of keys(app.actions)) {\n    permission.executeAction.add(a, accessLevel);\n  }\n\n  $(permission, [\n    values,\n    filter(p => !p.isNode),\n    each(p => p.add(accessLevel)),\n  ]);\n\n  return accessLevel.permissions;\n};\n","import { difference, map, join } from 'lodash/fp';\nimport {\n  getLock, isNolock, releaseLock, $,\n  apiWrapper, events,\n} from '../common';\nimport {\n  USERS_LOCK_FILE, ACCESS_LEVELS_FILE,\n  getUserByName, USERS_LIST_FILE,\n} from './authCommon';\nimport { permission } from './permissions';\nimport { NotFoundError } from '../common/errors';\n\nexport const setUserAccessLevels = app => async (userName, accessLevels) => apiWrapper(\n  app,\n  events.authApi.setUserAccessLevels,\n  permission.setUserAccessLevels.isAuthorized,\n  { userName, accessLevels },\n  _setUserAccessLevels, app, userName, accessLevels,\n);\n\nexport const _setUserAccessLevels = async (app, username, accessLevels) => {\n  const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0);\n\n  const actualAccessLevels = $(\n    await app.datastore.loadJson(ACCESS_LEVELS_FILE),\n    [\n      l => l.levels,\n      map(l => l.name),\n    ],\n  );\n\n  const missing = difference(accessLevels)(actualAccessLevels);\n  if (missing.length > 0) {\n    throw new Error(`Invalid access levels supplied: ${join(', ', missing)}`);\n  }\n\n  if (isNolock(lock)) { throw new Error('Could set user access levels cannot get lock'); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n    const user = getUserByName(users, username);\n    if (!user) { throw new NotFoundError(`Could not find user with ${username}`); }\n\n    user.accessLevels = accessLevels;\n    await app.datastore.updateJson(USERS_LIST_FILE, users);\n  } finally {\n    releaseLock(app, lock);\n  }\n};\n","import {\n  authenticate,\n  authenticateTemporaryAccess,\n} from './authenticate';\nimport { createTemporaryAccess } from './createTemporaryAccess';\nimport { createUser } from './createUser';\nimport { enableUser, disableUser } from './enableUser';\nimport { loadAccessLevels } from './loadAccessLevels';\nimport { getNewAccessLevel } from './getNewAccessLevel';\nimport { getNewUser, getNewUserAuth } from './getNewUser';\nimport { getUsers } from './getUsers';\nimport { isAuthorized } from './isAuthorized';\nimport { saveAccessLevels } from './saveAccessLevels';\nimport {\n  changeMyPassword,\n  scorePassword, setPasswordFromTemporaryCode,\n  isValidPassword,\n} from './setPassword';\nimport { validateUser } from './validateUser';\nimport { validateAccessLevels } from './validateAccessLevels';\nimport { generateFullPermissions } from './generateFullPermissions';\nimport { setUserAccessLevels } from './setUserAccessLevels';\n\nexport const getAuthApi = app => ({\n  authenticate: authenticate(app),\n  authenticateTemporaryAccess: authenticateTemporaryAccess(app),\n  createTemporaryAccess: createTemporaryAccess(app),\n  createUser: createUser(app),\n  loadAccessLevels: loadAccessLevels(app),\n  enableUser: enableUser(app),\n  disableUser: disableUser(app),\n  getNewAccessLevel: getNewAccessLevel(app),\n  getNewUser: getNewUser(app),\n  getNewUserAuth: getNewUserAuth(app),\n  getUsers: getUsers(app),\n  saveAccessLevels: saveAccessLevels(app),\n  isAuthorized: isAuthorized(app),\n  changeMyPassword: changeMyPassword(app),\n  setPasswordFromTemporaryCode: setPasswordFromTemporaryCode(app),\n  scorePassword,\n  isValidPassword: isValidPassword(app),\n  validateUser: validateUser(app),\n  validateAccessLevels: validateAccessLevels(app),\n  generateFullPermissions: () => generateFullPermissions(app),\n  setUserAccessLevels: setUserAccessLevels(app),\n});\n\nexport default getAuthApi;\n","import { permission } from '../authApi/permissions';\nimport { apiWrapperSync } from '../common/apiWrapper';\nimport { events } from '../common/events';\n\nexport const executeAction = app => (actionName, options) => {\n  apiWrapperSync(\n    app,\n    events.actionsApi.execute,\n    permission.executeAction.isAuthorized(actionName),\n    { actionName, options },\n    app.actions[actionName], options,\n  );\n};\n\nexport const _executeAction = (behaviourSources, action, options) => behaviourSources[action.behaviourSource][action.behaviourName](options);\n","import { executeAction } from './execute';\n\nexport const getActionsApi = app => ({\n  execute: executeAction(app),\n});\n\nexport default getActionsApi;\n","import { has } from 'lodash/fp';\n\nconst publish = handlers => async (eventName, context = {}) => {\n  if (!has(eventName)(handlers)) return;\n\n  for (const handler of handlers[eventName]) {\n    await handler(eventName, context);\n  }\n};\n\nconst subscribe = handlers => (eventName, handler) => {\n  if (!has(eventName)(handlers)) {\n    handlers[eventName] = [];\n  }\n  handlers[eventName].push(handler);\n};\n\nexport const createEventAggregator = () => {\n  const handlers = {};\n  const eventAggregator = ({\n    publish: publish(handlers),\n    subscribe: subscribe(handlers),\n  });\n  return eventAggregator;\n};\n\nexport default createEventAggregator;\n","import { retry } from '../common/index';\nimport { NotFoundError } from '../common/errors';\n\nconst createJson = originalCreateFile => async (key, obj, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, key, JSON.stringify(obj));\n\nconst createNewFile = originalCreateFile => async (path, content, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, path, content);\n\nconst loadJson = datastore => async (key, retries = 3, delay = 100) => {\n  try {\n    return await retry(JSON.parse, retries, delay, await datastore.loadFile(key));\n  } catch (err) {\n    const newErr = new NotFoundError(err.message);\n    newErr.stack = err.stack;\n    throw(newErr);\n  }\n}\n\nconst updateJson = datastore => async (key, obj, retries = 3, delay = 100) => {\n  try {\n    return await retry(datastore.updateFile, retries, delay, key, JSON.stringify(obj));\n  } catch (err) {\n    const newErr = new NotFoundError(err.message);\n    newErr.stack = err.stack;\n    throw(newErr);\n  }\n}\n\nexport const setupDatastore = (datastore) => {\n  const originalCreateFile = datastore.createFile;\n  datastore.loadJson = loadJson(datastore);\n  datastore.createJson = createJson(originalCreateFile);\n  datastore.updateJson = updateJson(datastore);\n  datastore.createFile = createNewFile(originalCreateFile);\n  if (datastore.createEmptyDb) { delete datastore.createEmptyDb; }\n  return datastore;\n};\n\nexport { createEventAggregator } from './eventAggregator';\n\nexport default setupDatastore;\n","import { \n  compileExpression as cExp, \n  compileCode as cCode \n} from '@nx-js/compiler-util';\n\nexport const compileCode = code => {\n  let func;  \n    \n  try {\n    func = cCode(code);\n  } catch(e) {\n    e.message = `Error compiling code : ${code} : ${e.message}`;\n    throw e;\n  }\n\n  return func;\n}\n\nexport const compileExpression = code => {\n  let func;  \n      \n  try {\n    func = cExp(code);\n  } catch(e) {\n    e.message = `Error compiling expression : ${code} : ${e.message}`;\n    throw e;\n  }\n  \n  return func;\n}\n","import {\n  isFunction, filter, map,\n  uniqBy, keys, difference,\n  join, reduce, find,\n} from 'lodash/fp';\nimport { compileExpression, compileCode } from '../common/compileCode';\nimport { $ } from '../common';\nimport { _executeAction } from './execute';\nimport { BadRequestError, NotFoundError } from '../common/errors';\n\nexport const initialiseActions = (subscribe, behaviourSources, actions, triggers, apis) => {\n  validateSources(behaviourSources, actions);\n  subscribeTriggers(subscribe, behaviourSources, actions, triggers, apis);\n  return createActionsCollection(behaviourSources, actions);\n};\n\nconst createActionsCollection = (behaviourSources, actions) => $(actions, [\n  reduce((all, a) => {\n    all[a.name] = opts => _executeAction(behaviourSources, a, opts);\n    return all;\n  }, {}),\n]);\n\nconst subscribeTriggers = (subscribe, behaviourSources, actions, triggers, apis) => {\n  const createOptions = (optionsCreator, eventContext) => {\n    if (!optionsCreator) return {};\n    const create = compileCode(optionsCreator);\n    return create({ context: eventContext, apis });\n  };\n\n  const shouldRunTrigger = (trigger, eventContext) => {\n    if (!trigger.condition) return true;\n    const shouldRun = compileExpression(trigger.condition);\n    return shouldRun({ context: eventContext });\n  };\n\n  for (let trig of triggers) {\n    subscribe(trig.eventName, async (ev, ctx) => {\n      if (shouldRunTrigger(trig, ctx)) {\n        await _executeAction(\n          behaviourSources,\n          find(a => a.name === trig.actionName)(actions),\n          createOptions(trig.optionsCreator, ctx),\n        );\n      }\n    });\n  }\n};\n\nconst validateSources = (behaviourSources, actions) => {\n  const declaredSources = $(actions, [\n    uniqBy(a => a.behaviourSource),\n    map(a => a.behaviourSource),\n  ]);\n\n  const suppliedSources = keys(behaviourSources);\n\n  const missingSources = difference(\n    declaredSources, suppliedSources,\n  );\n\n  if (missingSources.length > 0) {\n    throw new BadRequestError(`Declared behaviour sources are not supplied: ${join(', ', missingSources)}`);\n  }\n\n  const missingBehaviours = $(actions, [\n    filter(a => !isFunction(behaviourSources[a.behaviourSource][a.behaviourName])),\n    map(a => `Action: ${a.name} : ${a.behaviourSource}.${a.behaviourName}`),\n  ]);\n\n  if (missingBehaviours.length > 0) {\n    throw new NotFoundError(`Missing behaviours: could not find behaviour functions: ${join(', ', missingBehaviours)}`);\n  }\n};\n","import {\n  map, filter, groupBy, split,\n  some, find,\n} from 'lodash/fp';\nimport {\n  LOCK_FILENAME, TRANSACTIONS_FOLDER, idSep, isUpdate,\n  nodeKeyHashFromBuildFolder, isBuildIndexFolder, getTransactionId,\n  isDelete, isCreate,\n} from './transactionsCommon';\nimport {\n  joinKey, $, none, isSomething,\n} from '../common';\nimport { getLastPartInKey, getNodeFromNodeKeyHash } from '../templateApi/hierarchy';\nimport { _load } from '../recordApi/load';\n\nexport const retrieve = async (app) => {\n  const transactionFiles = await app.datastore.getFolderContents(\n    TRANSACTIONS_FOLDER,\n  );\n\n  let transactions = [];\n\n  if (some(isBuildIndexFolder)(transactionFiles)) {\n    const buildIndexFolder = find(isBuildIndexFolder)(transactionFiles);\n\n    transactions = await retrieveBuildIndexTransactions(\n      app,\n      joinKey(TRANSACTIONS_FOLDER, buildIndexFolder),\n    );\n  }\n\n  if (transactions.length > 0) return transactions;\n\n  return await retrieveStandardTransactions(\n    app, transactionFiles,\n  );\n};\n\nconst retrieveBuildIndexTransactions = async (app, buildIndexFolder) => {\n  const childFolders = await app.datastore.getFolderContents(buildIndexFolder);\n  if (childFolders.length === 0) {\n    // cleanup\n    await app.datastore.deleteFolder(buildIndexFolder);\n    return [];\n  }\n\n  const getTransactionFiles = async (childFolderIndex = 0) => {\n    if (childFolderIndex >= childFolders.length) return [];\n\n    const childFolderKey = joinKey(buildIndexFolder, childFolders[childFolderIndex]);\n    const files = await app.datastore.getFolderContents(\n      childFolderKey,\n    );\n\n    if (files.length === 0) {\n      await app.datastore.deleteFolder(childFolderKey);\n      return await getTransactionFiles(childFolderIndex + 1);\n    }\n\n    return { childFolderKey, files };\n  };\n\n  const transactionFiles = await getTransactionFiles();\n\n  if (transactionFiles.files.length === 0) return [];\n\n  const transactions = $(transactionFiles.files, [\n    map(parseTransactionId),\n  ]);\n\n  for (const t of transactions) {\n    const transactionContent = await app.datastore.loadJson(\n      joinKey(\n        transactionFiles.childFolderKey,\n        t.fullId,\n      ),\n    );\n    t.record = await _load(app, transactionContent.recordKey);\n  }\n\n  transactions.indexNode = $(buildIndexFolder, [\n    getLastPartInKey,\n    nodeKeyHashFromBuildFolder,\n    getNodeFromNodeKeyHash(app.hierarchy),\n  ]);\n\n  transactions.folderKey = transactionFiles.childFolderKey;\n\n  return transactions;\n};\n\nconst retrieveStandardTransactions = async (app, transactionFiles) => {\n  const transactionIds = $(transactionFiles, [\n    filter(f => f !== LOCK_FILENAME\n                    && !isBuildIndexFolder(f)),\n    map(parseTransactionId),\n  ]);\n\n  const transactionIdsByRecord = $(transactionIds, [\n    groupBy('recordId'),\n  ]);\n\n  const dedupedTransactions = [];\n\n  const verify = async (t) => {\n    if (t.verified === true) return t;\n\n    const id = getTransactionId(\n      t.recordId,\n      t.transactionType,\n      t.uniqueId,\n    );\n\n    const transaction = await app.datastore.loadJson(\n      joinKey(TRANSACTIONS_FOLDER, id),\n    );\n\n    if (isDelete(t)) {\n      t.record = transaction.record;\n      t.verified = true;\n      return t;\n    }\n\n    const rec = await _load(\n      app,\n      transaction.recordKey,\n    );\n    if (rec.transactionId === id) {\n      t.record = rec;\n      if (transaction.oldRecord) { t.oldRecord = transaction.oldRecord; }\n      t.verified = true;\n    } else {\n      t.verified = false;\n    }\n\n    return t;\n  };\n\n  const pickOne = async (trans, forType) => {\n    const transForType = filter(forType)(trans);\n    if (transForType.length === 1) {\n      const t = await verify(transForType[0]);\n      return (t.verified === true ? t : null);\n    }\n    for (let t of transForType) {\n      t = await verify(t);\n      if (t.verified === true) { return t; }\n    }\n\n    return null;\n  };\n\n  for (const recordId in transactionIdsByRecord) {\n    const transIdsForRecord = transactionIdsByRecord[recordId];\n    if (transIdsForRecord.length === 1) {\n      const t = await verify(transIdsForRecord[0]);\n      if (t.verified) { dedupedTransactions.push(t); }\n      continue;\n    }\n    if (some(isDelete)(transIdsForRecord)) {\n      const t = await verify(find(isDelete)(transIdsForRecord));\n      if (t.verified) { dedupedTransactions.push(t); }\n      continue;\n    }\n    if (some(isUpdate)(transIdsForRecord)) {\n      const upd = await pickOne(transIdsForRecord, isUpdate);\n      if (isSomething(upd) && upd.verified) { dedupedTransactions.push(upd); }\n      continue;\n    }\n    if (some(isCreate)(transIdsForRecord)) {\n      const cre = await pickOne(transIdsForRecord, isCreate);\n      if (isSomething(cre)) { dedupedTransactions.push(cre); }\n      continue;\n    }\n  }\n\n  const duplicates = $(transactionIds, [\n    filter(t => none(ddt => ddt.uniqueId === t.uniqueId)(dedupedTransactions)),\n  ]);\n\n\n  const deletePromises = map(t => app.datastore.deleteFile(\n    joinKey(\n      TRANSACTIONS_FOLDER,\n      getTransactionId(\n        t.recordId,\n        t.transactionType,\n        t.uniqueId,\n      ),\n    ),\n  ))(duplicates);\n\n  await Promise.all(deletePromises);\n\n  return dedupedTransactions;\n};\n\nconst parseTransactionId = (id) => {\n  const splitId = split(idSep)(id);\n  return ({\n    recordId: splitId[0],\n    transactionType: splitId[1],\n    uniqueId: splitId[2],\n    fullId: id,\n  });\n};\n","import { orderBy } from 'lodash';\nimport {\n  reduce, find, includes, flatten, union,\n  filter, each, map,\n} from 'lodash/fp';\nimport {\n  joinKey, splitKey, isNonEmptyString,\n  isNothing, $, isSomething,\n} from '../common';\nimport {\n  getFlattenedHierarchy, getNode, getRecordNodeId,\n  getExactNodeForKey, recordNodeIdIsAllowed,\n  isRecord, isGlobalIndex,\n} from '../templateApi/hierarchy';\nimport { indexTypes } from '../templateApi/indexes';\nimport { getIndexDir } from \"../indexApi/getIndexDir\";\nimport { getRecordInfo} from \"../recordApi/recordInfo\";\n\nexport const getRelevantAncestorIndexes = (hierarchy, record) => {\n  const key = record.key;\n  const keyParts = splitKey(key);\n  const nodeId = getRecordNodeId(key);\n\n  const flatHierarchy = orderBy(getFlattenedHierarchy(hierarchy),\n    [node => node.pathRegx().length],\n    ['desc']);\n\n  const makeindexNodeAndDir_ForAncestorIndex = (indexNode, parentRecordDir) => makeIndexNodeAndDir(indexNode, joinKey(parentRecordDir, indexNode.name));\n\n  const traverseAncestorIndexesInPath = () => reduce((acc, part) => {\n    const currentIndexKey = joinKey(acc.lastIndexKey, part);\n    acc.lastIndexKey = currentIndexKey;\n    const testPathRegx = p => new RegExp(`${p.pathRegx()}$`).test(currentIndexKey);\n    const nodeMatch = find(testPathRegx)(flatHierarchy);\n\n    if (isNothing(nodeMatch)) { return acc; }\n\n    if (!isRecord(nodeMatch)\n                || nodeMatch.indexes.length === 0) { return acc; }\n\n    const indexes = $(nodeMatch.indexes, [\n      filter(i => i.indexType === indexTypes.ancestor\n                        && (i.allowedRecordNodeIds.length === 0\n                         || includes(nodeId)(i.allowedRecordNodeIds))),\n    ]);\n\n    const currentRecordDir = getRecordInfo(hierarchy, currentIndexKey).dir;\n\n    each(v => acc.nodesAndKeys.push(\n      makeindexNodeAndDir_ForAncestorIndex(v, currentRecordDir),\n    ))(indexes);\n\n    return acc;\n  }, { lastIndexKey: '', nodesAndKeys: [] })(keyParts).nodesAndKeys;\n\n  const rootIndexes = $(flatHierarchy, [\n    filter(n => isGlobalIndex(n) && recordNodeIdIsAllowed(n)(nodeId)),\n    map(i => makeIndexNodeAndDir(\n              i, \n              getIndexDir(hierarchy, i.nodeKey()))),\n  ]);\n\n  return union(traverseAncestorIndexesInPath())(rootIndexes);\n};\n\nexport const getRelevantReverseReferenceIndexes = (hierarchy, record) => $(record.key, [\n  getExactNodeForKey(hierarchy),\n  n => n.fields,\n  filter(f => f.type === 'reference'\n                    && isSomething(record[f.name])\n                    && isNonEmptyString(record[f.name].key)),\n  map(f => $(f.typeOptions.reverseIndexNodeKeys, [\n    map(n => ({\n      recordNode: getNode(hierarchy, n),\n      field: f,\n    })),\n  ])),\n  flatten,\n  map(n => makeIndexNodeAndDir(\n    n.recordNode,\n    joinKey(\n      getRecordInfo(hierarchy, record[n.field.name].key).dir, \n      n.recordNode.name),\n  )),\n]);\n\nconst makeIndexNodeAndDir = (indexNode, indexDir) => ({ indexNode, indexDir });\n\nexport default getRelevantAncestorIndexes;\n","  // adapted from https://github.com/dex4er/js-promise-writable\n  // Thank you :) \n  export const promiseWriteableStream = stream => {\n  \n    let _errored;\n  \n    const _errorHandler = err => {\n        _errored = err;\n    };\n\n    stream.on(\"error\", _errorHandler);    \n  \n    const write = chunk => {  \n      let rejected = false;\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err);\n        }\n  \n        if (!stream.writable || stream.closed || stream.destroyed) {\n          return reject(new Error(\"write after end\"));\n        }\n  \n        const writeErrorHandler = err => {\n          _errored = undefined;\n          rejected = true;\n          reject(err);\n        }\n  \n        stream.once(\"error\", writeErrorHandler);\n  \n        const canWrite = stream.write(chunk);\n  \n        stream.removeListener(\"error\", writeErrorHandler);\n  \n        if (canWrite) {\n          if (!rejected) {\n            resolve(chunk.length);\n          }\n        } else {\n          const errorHandler = err => {\n            _errored = undefined;\n            removeListeners();\n            reject(err);\n          }\n  \n          const drainHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const closeHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const finishHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const removeListeners = () => {\n            stream.removeListener(\"close\", closeHandler);\n            stream.removeListener(\"drain\", drainHandler);\n            stream.removeListener(\"error\", errorHandler);\n            stream.removeListener(\"finish\", finishHandler);\n          }\n  \n          stream.on(\"close\", closeHandler);\n          stream.on(\"drain\", drainHandler);\n          stream.on(\"error\", errorHandler);\n          stream.on(\"finish\", finishHandler);\n        }\n      })\n    }\n  \n    const end = () => {\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err);\n        }\n  \n        if (!stream.writable || stream.closed || stream.destroyed) {\n          return resolve();\n        }\n  \n        const finishHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const errorHandler = (err) => {\n          _errored = undefined;\n          removeListeners();\n          reject(err);\n        }\n  \n        const removeListeners = () => {\n          stream.removeListener(\"error\", errorHandler);\n          stream.removeListener(\"finish\", finishHandler);\n        }\n  \n        stream.on(\"finish\", finishHandler);\n        stream.on(\"error\", errorHandler);\n  \n        stream.end();\n      })\n    }\n\n    return {write, end};\n  }\n  \n  export default promiseWriteableStream\n  ","import { ensureShardNameIsInShardMap } from './sharding';\nimport { getIndexWriter } from './serializer';\nimport { isShardedIndex, getParentKey } from '../templateApi/hierarchy';\nimport {promiseWriteableStream} from \"./promiseWritableStream\";\nimport {promiseReadableStream} from \"./promiseReadableStream\";\n\nexport const applyToShard = async (hierarchy, store, indexDir,\n  indexNode, indexShardKey, recordsToWrite, keysToRemove) => {\n  const createIfNotExists = recordsToWrite.length > 0;\n  const writer = await getWriter(hierarchy, store, indexDir, indexShardKey, indexNode, createIfNotExists);\n  if (writer === SHARD_DELETED) return;\n\n  await writer.updateIndex(recordsToWrite, keysToRemove);\n  await swapTempFileIn(store, indexShardKey);\n};\n\nconst SHARD_DELETED = 'SHARD_DELETED';\nconst getWriter = async (hierarchy, store, indexDir, indexedDataKey, indexNode, createIfNotExists) => {\n  let readableStream = null;\n\n  if (isShardedIndex(indexNode)) {\n    await ensureShardNameIsInShardMap(store, indexDir, indexedDataKey);\n    if(!await store.exists(indexedDataKey)) {\n      if (await store.exists(getParentKey(indexedDataKey))) {\n        await store.createFile(indexedDataKey, \"\");\n      } else {\n        return SHARD_DELETED;\n      }\n    }\n  }\n\n  try {\n\n    readableStream = promiseReadableStream(\n        await store.readableFileStream(indexedDataKey)\n    );\n\n  } catch (e) {\n\n    if (await store.exists(indexedDataKey)) {\n      throw e;\n    } else {\n      if (createIfNotExists) { \n        if(await store.exists(getParentKey(indexedDataKey))) {\n          await store.createFile(indexedDataKey, '');     \n        } else {\n          return SHARD_DELETED; \n        }\n      } else { \n        return SHARD_DELETED; \n      }\n\n      readableStream = promiseReadableStream(\n          await store.readableFileStream(indexedDataKey)\n      );\n\n    }\n  }\n\n  const writableStream = promiseWriteableStream(\n      await store.writableFileStream(indexedDataKey + \".temp\")\n  );\n\n  return getIndexWriter(\n    hierarchy, indexNode,\n        readableStream, writableStream\n  );\n};\n\nconst swapTempFileIn = async (store, indexedDataKey, isRetry = false) => {\n  const tempFile = `${indexedDataKey}.temp`;\n  try {\n    await store.deleteFile(indexedDataKey);\n  } catch (e) {\n    // ignore failure, incase it has not been created yet\n\n    // if parent folder does not exist, assume that this index\n    // should not be there\n    if(!await store.exists(getParentKey(indexedDataKey))) {\n      return;\n    }\n  }\n  try {\n    await store.renameFile(tempFile, indexedDataKey);\n  } catch (e) {\n    // retrying in case delete failure was for some other reason\n    if (!isRetry) {\n      await swapTempFileIn(store, indexedDataKey, true);\n    } else {\n      throw new Error(\"Failed to swap in index filed: \" + e.message);\n    }\n  }\n};\n","import {\n  filter, map, isUndefined, includes,\n  flatten, intersectionBy,\n  isEqual, pull, keys,\n  differenceBy, difference,\n} from 'lodash/fp';\nimport { union } from 'lodash';\nimport {\n  getRelevantAncestorIndexes,\n  getRelevantReverseReferenceIndexes,\n} from '../indexing/relevant';\nimport { evaluate } from '../indexing/evaluate';\nimport {\n  $, isSomething,\n  isNonEmptyArray, joinKey,\n  isNonEmptyString,\n} from '../common';\nimport { getIndexedDataKey } from '../indexing/sharding';\nimport {\n  isUpdate, isCreate,\n  isDelete, isBuildIndex,\n} from './transactionsCommon';\nimport { applyToShard } from '../indexing/apply';\nimport {\n  getActualKeyOfParent,\n  isGlobalIndex, fieldReversesReferenceToIndex, isReferenceIndex,\n  getExactNodeForKey,\n} from '../templateApi/hierarchy';\nimport { getRecordInfo } from \"../recordApi/recordInfo\";\nimport { getIndexDir } from '../indexApi/getIndexDir';\n\nexport const executeTransactions = app => async (transactions) => {\n  const recordsByShard = mappedRecordsByIndexShard(app.hierarchy, transactions);\n\n  for (const shard of keys(recordsByShard)) {\n    await applyToShard(\n      app.hierarchy, app.datastore,\n      recordsByShard[shard].indexDir,\n      recordsByShard[shard].indexNode,\n      shard,\n      recordsByShard[shard].writes,\n      recordsByShard[shard].removes,\n    );\n  }\n};\n\nconst mappedRecordsByIndexShard = (hierarchy, transactions) => {\n  const updates = getUpdateTransactionsByShard(\n    hierarchy, transactions,\n  );\n\n  const created = getCreateTransactionsByShard(\n    hierarchy, transactions,\n  );\n  const deletes = getDeleteTransactionsByShard(\n    hierarchy, transactions,\n  );\n\n  const indexBuild = getBuildIndexTransactionsByShard(\n    hierarchy,\n    transactions,\n  );\n\n  const toRemove = [\n    ...deletes,\n    ...updates.toRemove,\n  ];\n\n  const toWrite = [\n    ...created,\n    ...updates.toWrite,\n    ...indexBuild,\n  ];\n\n  const transByShard = {};\n\n  const initialiseShard = (t) => {\n    if (isUndefined(transByShard[t.indexShardKey])) {\n      transByShard[t.indexShardKey] = {\n        writes: [],\n        removes: [],\n        indexDir: t.indexDir,\n        indexNodeKey: t.indexNode.nodeKey(),\n        indexNode: t.indexNode,\n      };\n    }\n  };\n\n  for (const trans of toWrite) {\n    initialiseShard(trans);\n    transByShard[trans.indexShardKey].writes.push(\n      trans.mappedRecord.result,\n    );\n  }\n\n  for (const trans of toRemove) {\n    initialiseShard(trans);\n    transByShard[trans.indexShardKey].removes.push(\n      trans.mappedRecord.result.key,\n    );\n  }\n\n  return transByShard;\n};\n\nconst getUpdateTransactionsByShard = (hierarchy, transactions) => {\n  const updateTransactions = $(transactions, [filter(isUpdate)]);\n\n  const evaluateIndex = (record, indexNodeAndPath) => {\n    const mappedRecord = evaluate(record)(indexNodeAndPath.indexNode);\n    return ({\n      mappedRecord,\n      indexNode: indexNodeAndPath.indexNode,\n      indexDir: indexNodeAndPath.indexDir,\n      indexShardKey: getIndexedDataKey(\n        indexNodeAndPath.indexNode,\n        indexNodeAndPath.indexDir,\n        mappedRecord.result,\n      ),\n    });\n  };\n\n  const getIndexNodesToApply = indexFilter => (t, indexes) => $(indexes, [\n    map(n => ({\n      old: evaluateIndex(t.oldRecord, n),\n      new: evaluateIndex(t.record, n),\n    })),\n    filter(indexFilter),\n  ]);\n\n  const toRemoveFilter = (n, isUnreferenced) => n.old.mappedRecord.passedFilter === true\n        && (n.new.mappedRecord.passedFilter === false\n            || isUnreferenced);\n\n  const toAddFilter = (n, isNewlyReferenced) => (n.old.mappedRecord.passedFilter === false\n        || isNewlyReferenced)\n        && n.new.mappedRecord.passedFilter === true;\n\n  const toUpdateFilter = n => n.new.mappedRecord.passedFilter === true\n        && n.old.mappedRecord.passedFilter === true\n        && !isEqual(n.old.mappedRecord.result,\n          n.new.mappedRecord.result);\n\n  const toRemove = [];\n  const toWrite = [];\n\n  for (const t of updateTransactions) {\n    const ancestorIdxs = getRelevantAncestorIndexes(\n      hierarchy, t.record,\n    );\n\n    const referenceChanges = diffReverseRefForUpdate(\n      hierarchy, t.oldRecord, t.record,\n    );\n\n    // old records to remove (filtered out)\n    const filteredOut_toRemove = union(\n      getIndexNodesToApply(toRemoveFilter)(t, ancestorIdxs),\n      // still referenced - check filter\n      getIndexNodesToApply(toRemoveFilter)(t, referenceChanges.notChanged),\n      // un referenced - remove if in there already\n      getIndexNodesToApply(n => toRemoveFilter(n, true))(t, referenceChanges.unReferenced),\n    );\n\n    // new records to add (filtered in)\n    const filteredIn_toAdd = union(\n      getIndexNodesToApply(toAddFilter)(t, ancestorIdxs),\n      // newly referenced - check filter\n      getIndexNodesToApply(n => toAddFilter(n, true))(t, referenceChanges.newlyReferenced),\n      // reference unchanged - rerun filter in case something else changed\n      getIndexNodesToApply(toAddFilter)(t, referenceChanges.notChanged),\n    );\n\n    const changed = union(\n      getIndexNodesToApply(toUpdateFilter)(t, ancestorIdxs),\n      // still referenced - recheck filter\n      getIndexNodesToApply(toUpdateFilter)(t, referenceChanges.notChanged),\n    );\n\n    const shardKeyChanged = $(changed, [\n      filter(c => c.old.indexShardKey !== c.new.indexShardKey),\n    ]);\n\n    const changedInSameShard = $(shardKeyChanged, [\n      difference(changed),\n    ]);\n\n    for (const res of shardKeyChanged) {\n      pull(res)(changed);\n      filteredOut_toRemove.push(res);\n      filteredIn_toAdd.push(res);\n    }\n\n    toRemove.push(\n      $(filteredOut_toRemove, [\n        map(i => i.old),\n      ]),\n    );\n\n    toWrite.push(\n      $(filteredIn_toAdd, [\n        map(i => i.new),\n      ]),\n    );\n\n    toWrite.push(\n      $(changedInSameShard, [\n        map(i => i.new),\n      ]),\n    );\n  }\n\n  return ({\n    toRemove: flatten(toRemove),\n    toWrite: flatten(toWrite),\n  });\n};\n\nconst getBuildIndexTransactionsByShard = (hierarchy, transactions) => {\n  const buildTransactions = $(transactions, [filter(isBuildIndex)]);\n  if (!isNonEmptyArray(buildTransactions)) return [];\n  const indexNode = transactions.indexNode;\n\n  const getIndexDirs = (t) => {\n    if (isGlobalIndex(indexNode)) {\n      return [indexNode.nodeKey()];\n    }\n\n    if (isReferenceIndex(indexNode)) {\n      const recordNode = getExactNodeForKey(hierarchy)(t.record.key);\n      const refFields = $(recordNode.fields, [\n        filter(fieldReversesReferenceToIndex(indexNode)),\n      ]);\n      const indexDirs = [];\n      for (const refField of refFields) {\n        const refValue = t.record[refField.name];\n        if (isSomething(refValue)\n                   && isNonEmptyString(refValue.key)) {\n          const indexDir = joinKey(\n            getRecordInfo(hierarchy, refValue.key).dir,\n            indexNode.name,\n          );\n\n          if (!includes(indexDir)(indexDirs)) { indexDirs.push(indexDir); }\n        }\n      }\n      return indexDirs;\n    }\n\n    const indexKey = joinKey(\n      getActualKeyOfParent(\n        indexNode.parent().nodeKey(),\n        t.record.key,\n      ),\n      indexNode.name,\n    );\n\n    return [getIndexDir(hierarchy, indexKey)];\n  };\n\n  return $(buildTransactions, [\n    map((t) => {\n      const mappedRecord = evaluate(t.record)(indexNode);\n      if (!mappedRecord.passedFilter) return null;\n      const indexDirs = getIndexDirs(t);\n      return $(indexDirs, [\n        map(indexDir => ({\n          mappedRecord,\n          indexNode,\n          indexDir,\n          indexShardKey: getIndexedDataKey(\n            indexNode,\n            indexDir,\n            mappedRecord.result,\n          ),\n        })),\n      ]);\n    }),\n    flatten,\n    filter(isSomething),\n  ]);\n};\n\nconst get_Create_Delete_TransactionsByShard = pred => (hierarchy, transactions) => {\n  const createTransactions = $(transactions, [filter(pred)]);\n\n  const getIndexNodesToApply = (t, indexes) => $(indexes, [\n    map((n) => {\n      const mappedRecord = evaluate(t.record)(n.indexNode);\n      return ({\n        mappedRecord,\n        indexNode: n.indexNode,\n        indexDir: n.indexDir,\n        indexShardKey: getIndexedDataKey(\n          n.indexNode,\n          n.indexDir,\n          mappedRecord.result,\n        ),\n      });\n    }),\n    filter(n => n.mappedRecord.passedFilter),\n  ]);\n\n  const allToApply = [];\n\n  for (const t of createTransactions) {\n    const ancestorIdxs = getRelevantAncestorIndexes(hierarchy, t.record);\n    const reverseRef = getRelevantReverseReferenceIndexes(hierarchy, t.record);\n\n    allToApply.push(\n      getIndexNodesToApply(t, ancestorIdxs),\n    );\n    allToApply.push(\n      getIndexNodesToApply(t, reverseRef),\n    );\n  }\n\n  return flatten(allToApply);\n};\n\nconst getDeleteTransactionsByShard = get_Create_Delete_TransactionsByShard(isDelete);\n\nconst getCreateTransactionsByShard = get_Create_Delete_TransactionsByShard(isCreate);\n\nconst diffReverseRefForUpdate = (appHierarchy, oldRecord, newRecord) => {\n  const oldIndexes = getRelevantReverseReferenceIndexes(\n    appHierarchy, oldRecord,\n  );\n  const newIndexes = getRelevantReverseReferenceIndexes(\n    appHierarchy, newRecord,\n  );\n\n  const unReferenced = differenceBy(\n    i => i.indexDir,\n    oldIndexes, newIndexes,\n  );\n\n  const newlyReferenced = differenceBy(\n    i => i.indexDir,\n    newIndexes, oldIndexes,\n  );\n\n  const notChanged = intersectionBy(\n    i => i.indexDir,\n    newIndexes, oldIndexes,\n  );\n\n  return {\n    unReferenced,\n    newlyReferenced,\n    notChanged,\n  };\n};\n","import { map } from 'lodash/fp';\nimport { retrieve } from './retrieve';\nimport { executeTransactions } from './execute';\nimport {\n  $, joinKey, getLock, isNolock, releaseLock,\n} from '../common';\nimport {\n  LOCK_FILE_KEY, TRANSACTIONS_FOLDER,\n  timeoutMilliseconds, getTransactionId,\n  maxLockRetries,\n} from './transactionsCommon';\n\nexport const cleanup = async (app) => {\n  const lock = await getTransactionLock(app);\n  if (isNolock(lock)) return;\n\n  try {\n    const transactions = await retrieve(app);\n    if (transactions.length > 0) {\n      await executeTransactions(app)(transactions);\n\n      const folder = transactions.folderKey\n        ? transactions.folderKey\n        : TRANSACTIONS_FOLDER;\n\n      const deleteFiles = $(transactions, [\n        map(t => joinKey(\n          folder,\n          getTransactionId(\n            t.recordId, t.transactionType,\n            t.uniqueId,\n          ),\n        )),\n        map(app.datastore.deleteFile),\n      ]);\n\n      await Promise.all(deleteFiles);\n    }\n  } finally {\n    await releaseLock(app, lock);\n  }\n};\n\nconst getTransactionLock = async app => await getLock(\n  app, LOCK_FILE_KEY,\n  timeoutMilliseconds, maxLockRetries,\n);\n","import { filter } from 'lodash/fp';\nimport { configFolder, appDefinitionFile, $ } from '../common';\nimport { TRANSACTIONS_FOLDER } from '../transactions/transactionsCommon';\nimport { AUTH_FOLDER, USERS_LIST_FILE, ACCESS_LEVELS_FILE } from '../authApi/authCommon';\nimport { initialiseRootCollections } from '../collectionApi/initialise';\nimport { initialiseIndex } from '../indexing/initialiseIndex';\nimport { getFlattenedHierarchy, isGlobalIndex, isSingleRecord } from '../templateApi/hierarchy';\nimport { _getNew } from \"../recordApi/getNew\";\nimport { _save } from \"../recordApi/save\";\n\nexport const initialiseData = async (datastore, applicationDefinition, accessLevels) => {\n  await datastore.createFolder(configFolder);\n  await datastore.createJson(appDefinitionFile, applicationDefinition);\n\n  await initialiseRootCollections(datastore, applicationDefinition.hierarchy);\n  await initialiseRootIndexes(datastore, applicationDefinition.hierarchy);\n\n  await datastore.createFolder(TRANSACTIONS_FOLDER);\n\n  await datastore.createFolder(AUTH_FOLDER);\n\n  await datastore.createJson(USERS_LIST_FILE, []);\n\n  await datastore.createJson(\n    ACCESS_LEVELS_FILE, \n    accessLevels ? accessLevels : { version: 0, levels: [] });\n\n  await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy);\n};\n\nconst initialiseRootIndexes = async (datastore, hierarchy) => {\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n  const globalIndexes = $(flathierarchy, [\n    filter(isGlobalIndex),\n  ]);\n\n  for (const index of globalIndexes) {\n    if (!await datastore.exists(index.nodeKey())) { \n      await initialiseIndex(datastore, '', index); \n    }\n  }\n};\n\nconst initialiseRootSingleRecords = async (datastore, hierarchy) => {\n  const app = { \n    publish:()=>{},\n    cleanupTransactions: () => {},\n    datastore, hierarchy \n  };\n\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n  const singleRecords = $(flathierarchy, [\n    filter(isSingleRecord),\n  ]);\n\n  for (let record of singleRecords) {\n    await datastore.createFolder(record.nodeKey());\n    const result = _getNew(record, \"\");\n    await _save(app,result);\n  }\n};\n","import { isNothing } from '../common';\n\nexport const getDatabaseManager = databaseManager => ({\n  createEmptyMasterDb: createEmptyMasterDb(databaseManager),\n  createEmptyInstanceDb: createEmptyInstanceDb(databaseManager),\n  getInstanceDbRootConfig: databaseManager.getInstanceDbRootConfig,\n  masterDatastoreConfig: getMasterDatastoreConfig(databaseManager),\n  getInstanceDatastoreConfig: getInstanceDatastoreConfig(databaseManager),\n});\n\nconst getMasterDatastoreConfig = databaseManager => databaseManager.getDatastoreConfig('master');\n\nconst getInstanceDatastoreConfig = databaseManager => (applicationId, instanceId) => databaseManager.getDatastoreConfig(\n  applicationId, instanceId,\n);\n\nconst createEmptyMasterDb = databaseManager => async () => await databaseManager.createEmptyDb('master');\n\nconst createEmptyInstanceDb = databaseManager => async (applicationId, instanceId) => {\n  if (isNothing(applicationId)) { throw new Error('CreateDb: application id not supplied'); }\n  if (isNothing(instanceId)) { throw new Error('CreateDb: instance id not supplied'); }\n\n  return await databaseManager.createEmptyDb(\n    applicationId,\n    instanceId,\n  );\n};\n","import getRecordApi from \"./recordApi\";\nimport getCollectionApi from \"./collectionApi\";\nimport getIndexApi from \"./indexApi\";\nimport getTemplateApi from \"./templateApi\";\nimport getAuthApi from \"./authApi\";\nimport getActionsApi from \"./actionsApi\";\nimport {setupDatastore, createEventAggregator} from \"./appInitialise\";\nimport {initialiseActions} from \"./actionsApi/initialise\"\nimport {isSomething} from \"./common\";\nimport {cleanup} from \"./transactions/cleanup\";\nimport {generateFullPermissions} from \"./authApi/generateFullPermissions\";\nimport {getApplicationDefinition} from \"./templateApi/getApplicationDefinition\";\nimport common from \"./common\";\nimport {getBehaviourSources} from \"./templateApi/getBehaviourSources\";\nimport hierarchy from \"./templateApi/hierarchy\";\n\nexport const getAppApis = async (store, behaviourSources = null, \n                                cleanupTransactions = null, \n                                getEpochTime = null,\n                                crypto = null,\n                                appDefinition = null) => {\n\n    store = setupDatastore(store);\n\n    if(!appDefinition)\n        appDefinition = await getApplicationDefinition(store)();\n\n    if(!behaviourSources)\n        behaviourSources = await getBehaviourSources(store);\n\n    const eventAggregator = createEventAggregator();\n\n    const app = {\n        datastore:store,\n        crypto,\n        publish:eventAggregator.publish,\n        hierarchy:appDefinition.hierarchy,\n        actions:appDefinition.actions\n    };\n\n    const templateApi = getTemplateApi(app);    \n\n    app.cleanupTransactions = isSomething(cleanupTransactions) \n                              ? cleanupTransactions\n                              : async () => await cleanup(app);\n\n    app.getEpochTime = isSomething(getEpochTime)\n                       ? getEpochTime\n                       : async () => (new Date()).getTime();\n\n    const recordApi = getRecordApi(app);\n    const collectionApi = getCollectionApi(app);\n    const indexApi = getIndexApi(app);\n    const authApi = getAuthApi(app);\n    const actionsApi = getActionsApi(app);\n\n    const authenticateAs = async (username, password) => {\n        app.user = await authApi.authenticate(username, password);\n    };\n\n    const withFullAccess = () => \n        userWithFullAccess(app);    \n\n    const asUser = (user) => {\n        app.user = user\n    };    \n\n    let apis = {\n        recordApi, \n        templateApi,\n        collectionApi,\n        indexApi,\n        authApi,\n        actionsApi,\n        subscribe: eventAggregator.subscribe,\n        authenticateAs,\n        withFullAccess,\n        asUser\n    };\n\n    apis.actions = initialiseActions(\n        eventAggregator.subscribe,\n        behaviourSources,\n        appDefinition.actions,\n        appDefinition.triggers,\n        apis);\n\n\n    return apis;\n};\n\nexport const userWithFullAccess = (app) => {\n    app.user = {\n        name: \"app\",\n        permissions : generateFullPermissions(app),\n        isUser:false,\n        temp:false\n    }\n    return app.user;\n};\n\nexport {events, eventsList} from \"./common/events\";\nexport {getTemplateApi} from \"./templateApi\";\nexport {getRecordApi} from \"./recordApi\";\nexport {getCollectionApi} from \"./collectionApi\";\nexport {getAuthApi} from \"./authApi\";\nexport {getIndexApi} from \"./indexApi\";\nexport {setupDatastore} from \"./appInitialise\";\nexport {getActionsApi} from \"./actionsApi\";\nexport {initialiseData} from \"./appInitialise/initialiseData\";\nexport {getDatabaseManager} from \"./appInitialise/databaseManager\";\nexport {hierarchy};\nexport {common};\n\nexport default getAppApis;"],"names":["union","reduce","generate","isUndefined","cloneDeep","split","flow","trim","replace","isArray","filter","isNull","join","dropRight","takeRight","head","isNaN","isEmpty","constant","some","isString","tail","includes","startsWith","findIndex","isInteger","isDate","toNumber","map","compileExpression","compileCode","keys","isFunction","countBy","last","find","take","first","intersection","has","merge","mapValues","makerule","isBoolean","options","typeConstraints","isNumber","isObjectLike","assign","all","getDefaultOptions","validateTypeConstraints","isObject","clone","values","keyBy","orderBy","flatten","concat","reverse","global","base64.fromByteArray","ieee754.read","ieee754.write","base64.toByteArray","read","difference","Buffer","readIndex","each","_","deleteRecord","validate","max","defaultCase","every","uniqBy","api","createTemporaryAccess","createUser","uniqWith","setUserAccessLevels","executeAction","cCode","cExp","groupBy","isEqual","pull","differenceBy","intersectionBy"],"mappings":"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"} diff --git a/packages/core/dist/budibase-core.esm.mjs b/packages/core/dist/budibase-core.esm.mjs deleted file mode 100644 index 92be43d1c1..0000000000 --- a/packages/core/dist/budibase-core.esm.mjs +++ /dev/null @@ -1,8276 +0,0 @@ -import { union, reduce, isUndefined, cloneDeep, split, toNumber, isArray as isArray$1, filter, isNull, join as join$1, isNaN as isNaN$1, isEmpty, constant, some, includes, isInteger, isDate, isString, map, keys, isFunction, countBy, last, find, take, first, intersection, mapValues, has, isBoolean, isNumber, isObjectLike, isObject, clone, values, keyBy, orderBy, flatten, concat, reverse, difference, merge as merge$1, each, takeRight as takeRight$1, max, defaultCase as defaultCase$1, uniqBy, every, uniqWith, groupBy, pull, differenceBy, intersectionBy, isEqual } from 'lodash/fp'; -import { generate } from 'shortid'; -import _, { flow, dropRight, head, takeRight, tail, startsWith, findIndex, replace, trim, merge, assign, each as each$1, find as find$1, join as join$2, orderBy as orderBy$1, union as union$1 } from 'lodash'; -import { compileCode as compileCode$1, compileExpression as compileExpression$1 } from '@nx-js/compiler-util'; -import lunr from 'lunr'; -import { Buffer as Buffer$1 } from 'safe-buffer'; - -const commonPlus = extra => union(['onBegin', 'onComplete', 'onError'])(extra); - -const common = () => commonPlus([]); - -const _events = { - recordApi: { - save: commonPlus([ - 'onInvalid', - 'onRecordUpdated', - 'onRecordCreated']), - delete: common(), - getContext: common(), - getNew: common(), - load: common(), - validate: common(), - uploadFile: common(), - downloadFile: common(), - }, - indexApi: { - buildIndex: common(), - listItems: common(), - delete: common(), - aggregates: common(), - }, - collectionApi: { - getAllowedRecordTypes: common(), - initialise: common(), - delete: common(), - }, - authApi: { - authenticate: common(), - authenticateTemporaryAccess: common(), - createTemporaryAccess: common(), - createUser: common(), - enableUser: common(), - disableUser: common(), - loadAccessLevels: common(), - getNewAccessLevel: common(), - getNewUser: common(), - getNewUserAuth: common(), - getUsers: common(), - saveAccessLevels: common(), - isAuthorized: common(), - changeMyPassword: common(), - setPasswordFromTemporaryCode: common(), - scorePassword: common(), - isValidPassword: common(), - validateUser: common(), - validateAccessLevels: common(), - setUserAccessLevels: common(), - }, - templateApi: { - saveApplicationHierarchy: common(), - saveActionsAndTriggers: common(), - }, - actionsApi: { - execute: common(), - }, -}; - -const _eventsList = []; - -const makeEvent = (area, method, name) => `${area}:${method}:${name}`; - -for (const areaKey in _events) { - for (const methodKey in _events[areaKey]) { - _events[areaKey][methodKey] = reduce((obj, s) => { - obj[s] = makeEvent(areaKey, methodKey, s); - return obj; - }, - {})(_events[areaKey][methodKey]); - } -} - - -for (const areaKey in _events) { - for (const methodKey in _events[areaKey]) { - for (const name in _events[areaKey][methodKey]) { - _eventsList.push( - _events[areaKey][methodKey][name], - ); - } - } -} - - -const events = _events; - -const eventsList = _eventsList; - -class BadRequestError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 400; - } -} - -class UnauthorisedError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 401; - } -} - -class ForbiddenError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 403; - } -} - -class NotFoundError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 404; - } -} - -const apiWrapper = async (app, eventNamespace, isAuthorized, eventContext, func, ...params) => { - pushCallStack(app, eventNamespace); - - if (!isAuthorized(app)) { - handleNotAuthorized(app, eventContext, eventNamespace); - return; - } - - const startDate = Date.now(); - const elapsed = () => (Date.now() - startDate); - - try { - await app.publish( - eventNamespace.onBegin, - eventContext, - ); - - const result = await func(...params); - - await publishComplete(app, eventContext, eventNamespace, elapsed, result); - return result; - } catch (error) { - await publishError(app, eventContext, eventNamespace, elapsed, error); - throw error; - } -}; - -const apiWrapperSync = (app, eventNamespace, isAuthorized, eventContext, func, ...params) => { - pushCallStack(app, eventNamespace); - - if (!isAuthorized(app)) { - handleNotAuthorized(app, eventContext, eventNamespace); - return; - } - - const startDate = Date.now(); - const elapsed = () => (Date.now() - startDate); - - try { - app.publish( - eventNamespace.onBegin, - eventContext, - ); - - const result = func(...params); - - publishComplete(app, eventContext, eventNamespace, elapsed, result); - return result; - } catch (error) { - publishError(app, eventContext, eventNamespace, elapsed, error); - throw error; - } -}; - -const handleNotAuthorized = (app, eventContext, eventNamespace) => { - const err = new UnauthorisedError(`Unauthorized: ${eventNamespace}`); - publishError(app, eventContext, eventNamespace, () => 0, err); - throw err; -}; - -const pushCallStack = (app, eventNamespace, seedCallId) => { - const callId = generate(); - - const createCallStack = () => ({ - seedCallId: !isUndefined(seedCallId) - ? seedCallId - : callId, - threadCallId: callId, - stack: [], - }); - - if (isUndefined(app.calls)) { - app.calls = createCallStack(); - } - - app.calls.stack.push({ - namespace: eventNamespace, - callId, - }); -}; - -const popCallStack = (app) => { - app.calls.stack.pop(); - if (app.calls.stack.length === 0) { - delete app.calls; - } -}; - -const publishError = async (app, eventContext, eventNamespace, elapsed, err) => { - const ctx = cloneDeep(eventContext); - ctx.error = err; - ctx.elapsed = elapsed(); - await app.publish( - eventNamespace.onError, - ctx, - ); - popCallStack(app); -}; - -const publishComplete = async (app, eventContext, eventNamespace, elapsed, result) => { - const endcontext = cloneDeep(eventContext); - endcontext.result = result; - endcontext.elapsed = elapsed(); - await app.publish( - eventNamespace.onComplete, - endcontext, - ); - popCallStack(app); - return result; -}; - -const lockOverlapMilliseconds = 10; - -const getLock = async (app, lockFile, timeoutMilliseconds, maxLockRetries, retryCount = 0) => { - try { - const timeout = (await app.getEpochTime()) - + timeoutMilliseconds; - - const lock = { - timeout, - key: lockFile, - totalTimeout: timeoutMilliseconds, - }; - - await app.datastore.createFile( - lockFile, - getLockFileContent( - lock.totalTimeout, - lock.timeout, - ), - ); - - return lock; - } catch (e) { - if (retryCount == maxLockRetries) { return NO_LOCK; } - - const lock = parseLockFileContent( - lockFile, - await app.datastore.loadFile(lockFile), - ); - - const currentEpochTime = await app.getEpochTime(); - - if (currentEpochTime < lock.timeout) { - return NO_LOCK; - } - - try { - await app.datastore.deleteFile(lockFile); - } catch (_) { - //empty - } - - await sleepForRetry(); - - return await getLock( - app, lockFile, timeoutMilliseconds, - maxLockRetries, retryCount + 1, - ); - } -}; - -const getLockFileContent = (totalTimeout, epochTime) => `${totalTimeout}:${epochTime.toString()}`; - -const parseLockFileContent = (key, content) => $(content, [ - split(':'), - parts => ({ - totalTimeout: new Number(parts[0]), - timeout: new Number(parts[1]), - key, - }), -]); - -const releaseLock = async (app, lock) => { - const currentEpochTime = await app.getEpochTime(); - // only release if not timedout - if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) { - try { - await app.datastore.deleteFile(lock.key); - } catch (_) { - //empty - } - } -}; - -const NO_LOCK = 'no lock'; -const isNolock = id => id === NO_LOCK; - -const sleepForRetry = () => new Promise(resolve => setTimeout(resolve, lockOverlapMilliseconds)); - -// this is the combinator function -const $$ = (...funcs) => arg => flow(funcs)(arg); - -// this is the pipe function -const $ = (arg, funcs) => $$(...funcs)(arg); - -const keySep = '/'; -const trimKeySep = str => trim(str, keySep); -const splitByKeySep = str => split(keySep)(str); -const safeKey = key => replace(`${keySep}${trimKeySep(key)}`, `${keySep}${keySep}`, keySep); -const joinKey = (...strs) => { - const paramsOrArray = strs.length === 1 & isArray$1(strs[0]) - ? strs[0] : strs; - return $(paramsOrArray, [ - filter(s => !isUndefined(s) - && !isNull(s) - && s.toString().length > 0), - join$1(keySep), - safeKey - ]); -}; -const splitKey = $$(trimKeySep, splitByKeySep); -const getDirFomKey = $$(splitKey, dropRight, p => joinKey(...p)); -const getFileFromKey = $$(splitKey, takeRight, head); - -const configFolder = `${keySep}.config`; -const fieldDefinitions = joinKey(configFolder, 'fields.json'); -const templateDefinitions = joinKey(configFolder, 'templates.json'); -const appDefinitionFile = joinKey(configFolder, 'appDefinition.json'); -const dirIndex = folderPath => joinKey(configFolder, 'dir', ...splitKey(folderPath), 'dir.idx'); -const getIndexKeyFromFileKey = $$(getDirFomKey, dirIndex); - -const ifExists = (val, exists, notExists) => (isUndefined(val) - ? isUndefined(notExists) ? (() => { })() : notExists() - : exists()); - -const getOrDefault = (val, defaultVal) => ifExists(val, () => val, () => defaultVal); - -const not = func => val => !func(val); -const isDefined = not(isUndefined); -const isNonNull = not(isNull); -const isNotNaN = not(isNaN$1); - -const allTrue = (...funcArgs) => val => reduce( - (result, conditionFunc) => (isNull(result) || result == true) && conditionFunc(val), - null)(funcArgs); - -const anyTrue = (...funcArgs) => val => reduce( - (result, conditionFunc) => result == true || conditionFunc(val), - null)(funcArgs); - -const insensitiveEquals = (str1, str2) => str1.trim().toLowerCase() === str2.trim().toLowerCase(); - -const isSomething = allTrue(isDefined, isNonNull, isNotNaN); -const isNothing = not(isSomething); -const isNothingOrEmpty = v => isNothing(v) || isEmpty(v); -const somethingOrGetDefault = getDefaultFunc => val => (isSomething(val) ? val : getDefaultFunc()); -const somethingOrDefault = (val, defaultVal) => somethingOrGetDefault(constant(defaultVal))(val); - -const mapIfSomethingOrDefault = (mapFunc, defaultVal) => val => (isSomething(val) ? mapFunc(val) : defaultVal); - -const mapIfSomethingOrBlank = mapFunc => mapIfSomethingOrDefault(mapFunc, ''); - -const none = predicate => collection => !some(predicate)(collection); - -const all = predicate => collection => none(v => !predicate(v))(collection); - -const isNotEmpty = ob => !isEmpty(ob); -const isNonEmptyArray = allTrue(isArray$1, isNotEmpty); -const isNonEmptyString = allTrue(isString, isNotEmpty); -const tryOr = failFunc => (func, ...args) => { - try { - return func.apply(null, ...args); - } catch (_) { - return failFunc(); - } -}; - -const tryAwaitOr = failFunc => async (func, ...args) => { - try { - return await func.apply(null, ...args); - } catch (_) { - return await failFunc(); - } -}; - -const defineError = (func, errorPrefix) => { - try { - return func(); - } catch (err) { - err.message = `${errorPrefix} : ${err.message}`; - throw err; - } -}; - -const tryOrIgnore = tryOr(() => { }); -const tryAwaitOrIgnore = tryAwaitOr(async () => { }); -const causesException = (func) => { - try { - func(); - return false; - } catch (e) { - return true; - } -}; - -const executesWithoutException = func => !causesException(func); - -const handleErrorWith = returnValInError => tryOr(constant(returnValInError)); - -const handleErrorWithUndefined = handleErrorWith(undefined); - -const switchCase = (...cases) => (value) => { - const nextCase = () => head(cases)[0](value); - const nextResult = () => head(cases)[1](value); - - if (isEmpty(cases)) return; // undefined - if (nextCase() === true) return nextResult(); - return switchCase(...tail(cases))(value); -}; - -const isValue = val1 => val2 => (val1 === val2); -const isOneOf = (...vals) => val => includes(val)(vals); -const defaultCase = constant(true); -const memberMatches = (member, match) => obj => match(obj[member]); - - -const StartsWith = searchFor => searchIn => startsWith(searchIn, searchFor); - -const contains = val => array => (findIndex(array, v => v === val) > -1); - -const getHashCode = (s) => { - let hash = 0; let i; let char; let - l; - if (s.length == 0) return hash; - for (i = 0, l = s.length; i < l; i++) { - char = s.charCodeAt(i); - hash = ((hash << 5) - hash) + char; - hash |= 0; // Convert to 32bit integer - } - - // converting to string, but dont want a "-" prefixed - if (hash < 0) { return `n${(hash * -1).toString()}`; } - return hash.toString(); -}; - -// thanks to https://blog.grossman.io/how-to-write-async-await-without-try-catch-blocks-in-javascript/ -const awEx = async (promise) => { - try { - const result = await promise; - return [undefined, result]; - } catch (error) { - return [error, undefined]; - } -}; - -const isSafeInteger = n => isInteger(n) - && n <= Number.MAX_SAFE_INTEGER - && n >= 0 - Number.MAX_SAFE_INTEGER; - -const toDateOrNull = s => (isNull(s) ? null - : isDate(s) ? s : new Date(s)); -const toBoolOrNull = s => (isNull(s) ? null - : s === 'true' || s === true); -const toNumberOrNull = s => (isNull(s) ? null - : toNumber(s)); - -const isArrayOfString = opts => isArray$1(opts) && all(isString)(opts); - -const pushAll = (target, items) => { - for(let i of items) target.push(i); -}; - -const pause = async duration => new Promise(res => setTimeout(res, duration)); - -const retry = async (fn, retries, delay, ...args) => { - try { - return await fn(...args); - } catch (err) { - if (retries > 1) { - return await pause(delay).then(async () => await retry(fn, (retries - 1), delay, ...args)); - } - throw err; - } -}; - -var index = { - ifExists, - getOrDefault, - isDefined, - isNonNull, - isNotNaN, - allTrue, - isSomething, - mapIfSomethingOrDefault, - mapIfSomethingOrBlank, - configFolder, - fieldDefinitions, - isNothing, - not, - switchCase, - defaultCase, - StartsWith, - contains, - templateDefinitions, - handleErrorWith, - handleErrorWithUndefined, - tryOr, - tryOrIgnore, - tryAwaitOr, - tryAwaitOrIgnore, - dirIndex, - keySep, - $, - $$, - getDirFomKey, - getFileFromKey, - splitKey, - somethingOrDefault, - getIndexKeyFromFileKey, - joinKey, - somethingOrGetDefault, - appDefinitionFile, - isValue, - all, - isOneOf, - memberMatches, - defineError, - anyTrue, - isNonEmptyArray, - causesException, - executesWithoutException, - none, - getHashCode, - awEx, - apiWrapper, - events, - eventsList, - isNothingOrEmpty, - isSafeInteger, - toNumber, - toDate: toDateOrNull, - toBool: toBoolOrNull, - isArrayOfString, - getLock, - NO_LOCK, - isNolock, - insensitiveEquals, - pause, - retry, - pushAll -}; - -const stringNotEmpty = s => isSomething(s) && s.trim().length > 0; - -const makerule = (field, error, isValid) => ({ field, error, isValid }); - -const validationError = (rule, item) => ({ ...rule, item }); - -const applyRuleSet = ruleSet => itemToValidate => $(ruleSet, [ - map(applyRule(itemToValidate)), - filter(isSomething), -]); - -const applyRule = itemTovalidate => rule => (rule.isValid(itemTovalidate) - ? null - : validationError(rule, itemTovalidate)); - -const filterEval = 'FILTER_EVALUATE'; -const filterCompile = 'FILTER_COMPILE'; -const mapEval = 'MAP_EVALUATE'; -const mapCompile = 'MAP_COMPILE'; - - -const getEvaluateResult = () => ({ - isError: false, - passedFilter: true, - result: null, -}); - -const compileFilter = index => compileExpression$1(index.filter); - -const compileMap = index => compileCode$1(index.map); - -const passesFilter = (record, index) => { - const context = { record }; - if (!index.filter) return true; - - const compiledFilter = defineError( - () => compileFilter(index), - filterCompile, - ); - - return defineError( - () => compiledFilter(context), - filterEval, - ); -}; - -const mapRecord = (record, index) => { - const recordClone = cloneDeep(record); - const context = { record: recordClone }; - - const map = index.map ? index.map : 'return {...record};'; - - const compiledMap = defineError( - () => compileCode$1(map), - mapCompile, - ); - - const mapped = defineError( - () => compiledMap(context), - mapEval, - ); - - const mappedKeys = keys(mapped); - for (let i = 0; i < mappedKeys.length; i++) { - const key = mappedKeys[i]; - mapped[key] = isUndefined(mapped[key]) ? null : mapped[key]; - if (isFunction(mapped[key])) { - delete mapped[key]; - } - } - - mapped.key = record.key; - mapped.sortKey = index.getSortKey - ? compileCode$1(index.getSortKey)(context) - : record.id; - - return mapped; -}; - -const evaluate = record => (index) => { - const result = getEvaluateResult(); - - try { - result.passedFilter = passesFilter(record, index); - } catch (err) { - result.isError = true; - result.passedFilter = false; - result.result = err.message; - } - - if (!result.passedFilter) return result; - - try { - result.result = mapRecord(record, index); - } catch (err) { - result.isError = true; - result.result = err.message; - } - - return result; -}; - -const indexTypes = { reference: 'reference', ancestor: 'ancestor' }; - -const indexRuleSet = [ - makerule('map', 'index has no map function', - index => isNonEmptyString(index.map)), - makerule('map', "index's map function does not compile", - index => !isNonEmptyString(index.map) - || executesWithoutException(() => compileMap(index))), - makerule('filter', "index's filter function does not compile", - index => !isNonEmptyString(index.filter) - || executesWithoutException(() => compileFilter(index))), - makerule('name', 'must declare a name for index', - index => isNonEmptyString(index.name)), - makerule('name', 'there is a duplicate named index on this node', - index => isEmpty(index.name) - || countBy('name')(index.parent().indexes)[index.name] === 1), - makerule('indexType', 'reference index may only exist on a record node', - index => isRecord(index.parent()) - || index.indexType !== indexTypes.reference), - makerule('indexType', `index type must be one of: ${join$1(', ')(keys(indexTypes))}`, - index => includes(index.indexType)(keys(indexTypes))), -]; - -const getFlattenedHierarchy = (appHierarchy, useCached = true) => { - if (isSomething(appHierarchy.getFlattenedHierarchy) && useCached) { return appHierarchy.getFlattenedHierarchy(); } - - const flattenHierarchy = (currentNode, flattened) => { - flattened.push(currentNode); - if ((!currentNode.children - || currentNode.children.length === 0) - && (!currentNode.indexes - || currentNode.indexes.length === 0) - && (!currentNode.aggregateGroups - || currentNode.aggregateGroups.length === 0)) { - return flattened; - } - - const unionIfAny = l2 => l1 => union(l1)(!l2 ? [] : l2); - - const children = $([], [ - unionIfAny(currentNode.children), - unionIfAny(currentNode.indexes), - unionIfAny(currentNode.aggregateGroups), - ]); - - for (const child of children) { - flattenHierarchy(child, flattened); - } - return flattened; - }; - - appHierarchy.getFlattenedHierarchy = () => flattenHierarchy(appHierarchy, []); - return appHierarchy.getFlattenedHierarchy(); -}; - -const getLastPartInKey = key => last(splitKey(key)); - -const getNodesInPath = appHierarchy => key => $(appHierarchy, [ - getFlattenedHierarchy, - filter(n => new RegExp(`${n.pathRegx()}`).test(key)), -]); - -const getExactNodeForKey = appHierarchy => key => $(appHierarchy, [ - getFlattenedHierarchy, - find(n => new RegExp(`${n.pathRegx()}$`).test(key)), -]); - -const getNodeForCollectionPath = appHierarchy => collectionKey => $(appHierarchy, [ - getFlattenedHierarchy, - find(n => (isCollectionRecord(n) - && new RegExp(`${n.collectionPathRegx()}$`).test(collectionKey))), -]); - -const hasMatchingAncestor = ancestorPredicate => decendantNode => switchCase( - - [node => isNothing(node.parent()), - constant(false)], - - [node => ancestorPredicate(node.parent()), - constant(true)], - - [defaultCase, - node => hasMatchingAncestor(ancestorPredicate)(node.parent())], - -)(decendantNode); - -const getNode = (appHierarchy, nodeKey) => $(appHierarchy, [ - getFlattenedHierarchy, - find(n => n.nodeKey() === nodeKey - || (isCollectionRecord(n) - && n.collectionNodeKey() === nodeKey)), -]); - -const getCollectionNode = (appHierarchy, nodeKey) => $(appHierarchy, [ - getFlattenedHierarchy, - find(n => (isCollectionRecord(n) - && n.collectionNodeKey() === nodeKey)), -]); - -const getNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => { - const nodeByKey = getExactNodeForKey(appHierarchy)(keyOrNodeKey); - return isNothing(nodeByKey) - ? getNode(appHierarchy, keyOrNodeKey) - : nodeByKey; -}; - -const getCollectionNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => { - const nodeByKey = getNodeForCollectionPath(appHierarchy)(keyOrNodeKey); - return isNothing(nodeByKey) - ? getCollectionNode(appHierarchy, keyOrNodeKey) - : nodeByKey; -}; - -const isNode = (appHierarchy, key) => isSomething(getExactNodeForKey(appHierarchy)(key)); - -const getActualKeyOfParent = (parentNodeKey, actualChildKey) => - $(actualChildKey, [ - splitKey, - take(splitKey(parentNodeKey).length), - ks => joinKey(...ks), - ]); - -const getParentKey = (key) => { - return $(key, [ - splitKey, - take(splitKey(key).length - 1), - joinKey, - ]); -}; - -const isKeyAncestorOf = ancestorKey => decendantNode => hasMatchingAncestor(p => p.nodeKey() === ancestorKey)(decendantNode); - -const hasNoMatchingAncestors = parentPredicate => node => !hasMatchingAncestor(parentPredicate)(node); - -const findField = (recordNode, fieldName) => find(f => f.name == fieldName)(recordNode.fields); - -const isAncestor = decendant => ancestor => isKeyAncestorOf(ancestor.nodeKey())(decendant); - -const isDecendant = ancestor => decendant => isAncestor(decendant)(ancestor); - -const getRecordNodeId = recordKey => $(recordKey, [ - splitKey, - last, - getRecordNodeIdFromId, -]); - -const getRecordNodeIdFromId = recordId => $(recordId, [split('-'), first, parseInt]); - -const getRecordNodeById = (hierarchy, recordId) => $(hierarchy, [ - getFlattenedHierarchy, - find(n => isRecord(n) - && n.nodeId === getRecordNodeIdFromId(recordId)), -]); - -const recordNodeIdIsAllowed = indexNode => nodeId => indexNode.allowedRecordNodeIds.length === 0 - || includes(nodeId)(indexNode.allowedRecordNodeIds); - -const recordNodeIsAllowed = indexNode => recordNode => recordNodeIdIsAllowed(indexNode)(recordNode.nodeId); - -const getAllowedRecordNodesForIndex = (appHierarchy, indexNode) => { - const recordNodes = $(appHierarchy, [ - getFlattenedHierarchy, - filter(isRecord), - ]); - - if (isGlobalIndex(indexNode)) { - return $(recordNodes, [ - filter(recordNodeIsAllowed(indexNode)), - ]); - } - - if (isAncestorIndex(indexNode)) { - return $(recordNodes, [ - filter(isDecendant(indexNode.parent())), - filter(recordNodeIsAllowed(indexNode)), - ]); - } - - if (isReferenceIndex(indexNode)) { - return $(recordNodes, [ - filter(n => some(fieldReversesReferenceToIndex(indexNode))(n.fields)), - ]); - } -}; - -const getNodeFromNodeKeyHash = hierarchy => hash => $(hierarchy, [ - getFlattenedHierarchy, - find(n => getHashCode(n.nodeKey()) === hash), -]); - -const isRecord = node => isSomething(node) && node.type === 'record'; -const isSingleRecord = node => isRecord(node) && node.isSingle; -const isCollectionRecord = node => isRecord(node) && !node.isSingle; -const isIndex = node => isSomething(node) && node.type === 'index'; -const isaggregateGroup = node => isSomething(node) && node.type === 'aggregateGroup'; -const isShardedIndex = node => isIndex(node) && isNonEmptyString(node.getShardName); -const isRoot = node => isSomething(node) && node.isRoot(); -const isDecendantOfARecord = hasMatchingAncestor(isRecord); -const isGlobalIndex = node => isIndex(node) && isRoot(node.parent()); -const isReferenceIndex = node => isIndex(node) && node.indexType === indexTypes.reference; -const isAncestorIndex = node => isIndex(node) && node.indexType === indexTypes.ancestor; - -const fieldReversesReferenceToNode = node => field => field.type === 'reference' - && intersection(field.typeOptions.reverseIndexNodeKeys)(map(i => i.nodeKey())(node.indexes)) - .length > 0; - -const fieldReversesReferenceToIndex = indexNode => field => field.type === 'reference' - && intersection(field.typeOptions.reverseIndexNodeKeys)([indexNode.nodeKey()]) - .length > 0; - -var hierarchy = { - getLastPartInKey, - getNodesInPath, - getExactNodeForKey, - hasMatchingAncestor, - getNode, - getNodeByKeyOrNodeKey, - isNode, - getActualKeyOfParent, - getParentKey, - isKeyAncestorOf, - hasNoMatchingAncestors, - findField, - isAncestor, - isDecendant, - getRecordNodeId, - getRecordNodeIdFromId, - getRecordNodeById, - recordNodeIdIsAllowed, - recordNodeIsAllowed, - getAllowedRecordNodesForIndex, - getNodeFromNodeKeyHash, - isRecord, - isCollectionRecord, - isIndex, - isaggregateGroup, - isShardedIndex, - isRoot, - isDecendantOfARecord, - isGlobalIndex, - isReferenceIndex, - isAncestorIndex, - fieldReversesReferenceToNode, - fieldReversesReferenceToIndex, - getFlattenedHierarchy, -}; - -const getSafeFieldParser = (tryParse, defaultValueFunctions) => (field, record) => { - if (has(field.name)(record)) { - return getSafeValueParser(tryParse, defaultValueFunctions)(record[field.name]); - } - return defaultValueFunctions[field.getUndefinedValue](); -}; - -const getSafeValueParser = (tryParse, defaultValueFunctions) => (value) => { - const parsed = tryParse(value); - if (parsed.success) { - return parsed.value; - } - return defaultValueFunctions.default(); -}; - -const getNewValue = (tryParse, defaultValueFunctions) => (field) => { - const getInitialValue = isUndefined(field) || isUndefined(field.getInitialValue) - ? 'default' - : field.getInitialValue; - - return has(getInitialValue)(defaultValueFunctions) - ? defaultValueFunctions[getInitialValue]() - : getSafeValueParser(tryParse, defaultValueFunctions)(getInitialValue); -}; - -const typeFunctions = specificFunctions => merge({ - value: constant, - null: constant(null), -}, specificFunctions); - -const validateTypeConstraints = validationRules => async (field, record, context) => { - const fieldValue = record[field.name]; - const validateRule = async r => (!await r.isValid(fieldValue, field.typeOptions, context) - ? r.getMessage(fieldValue, field.typeOptions) - : ''); - - const errors = []; - for (const r of validationRules) { - const err = await validateRule(r); - if (isNotEmpty(err)) errors.push(err); - } - - return errors; -}; - -const getDefaultOptions = mapValues(v => v.defaultValue); - -const makerule$1 = (isValid, getMessage) => ({ isValid, getMessage }); -const parsedFailed = val => ({ success: false, value: val }); -const parsedSuccess = val => ({ success: true, value: val }); -const getDefaultExport = (name, tryParse, functions, options, validationRules, sampleValue, stringify) => ({ - getNew: getNewValue(tryParse, functions), - safeParseField: getSafeFieldParser(tryParse, functions), - safeParseValue: getSafeValueParser(tryParse, functions), - tryParse, - name, - getDefaultOptions: () => getDefaultOptions(cloneDeep(options)), - optionDefinitions: options, - validateTypeConstraints: validateTypeConstraints(validationRules), - sampleValue, - stringify: val => (val === null || val === undefined - ? '' : stringify(val)), - getDefaultValue: functions.default, -}); - -const stringFunctions = typeFunctions({ - default: constant(null), -}); - -const stringTryParse = switchCase( - [isString, parsedSuccess], - [isNull, parsedSuccess], - [defaultCase, v => parsedSuccess(v.toString())], -); - -const options = { - maxLength: { - defaultValue: null, - isValid: n => n === null || isSafeInteger(n) && n > 0, - requirementDescription: 'max length must be null (no limit) or a greater than zero integer', - parse: toNumberOrNull, - }, - values: { - defaultValue: null, - isValid: v => v === null || (isArrayOfString(v) && v.length > 0 && v.length < 10000), - requirementDescription: "'values' must be null (no values) or an arry of at least one string", - parse: s => s, - }, - allowDeclaredValuesOnly: { - defaultValue: false, - isValid: isBoolean, - requirementDescription: 'allowDeclaredValuesOnly must be true or false', - parse: toBoolOrNull, - }, -}; - -const typeConstraints = [ - makerule$1(async (val, opts) => val === null || opts.maxLength === null || val.length <= opts.maxLength, - (val, opts) => `value exceeds maximum length of ${opts.maxLength}`), - makerule$1(async (val, opts) => val === null - || opts.allowDeclaredValuesOnly === false - || includes(val)(opts.values), - (val) => `"${val}" does not exist in the list of allowed values`), -]; - -var string = getDefaultExport( - 'string', - stringTryParse, - stringFunctions, - options, - typeConstraints, - 'abcde', - str => str, -); - -const boolFunctions = typeFunctions({ - default: constant(null), -}); - -const boolTryParse = switchCase( - [isBoolean, parsedSuccess], - [isNull, parsedSuccess], - [isOneOf('true', '1', 'yes', 'on'), () => parsedSuccess(true)], - [isOneOf('false', '0', 'no', 'off'), () => parsedSuccess(false)], - [defaultCase, parsedFailed], -); - -const options$1 = { - allowNulls: { - defaultValue: true, - isValid: isBoolean, - requirementDescription: 'must be a true or false', - parse: toBoolOrNull, - }, -}; - -const typeConstraints$1 = [ - makerule$1(async (val, opts) => opts.allowNulls === true || val !== null, - () => 'field cannot be null'), -]; - -var bool = getDefaultExport( - 'bool', boolTryParse, boolFunctions, - options$1, typeConstraints$1, true, JSON.stringify, -); - -const numberFunctions = typeFunctions({ - default: constant(null), -}); - -const parseStringtoNumberOrNull = (s) => { - const num = Number(s); - return isNaN(num) ? parsedFailed(s) : parsedSuccess(num); -}; - -const numberTryParse = switchCase( - [isNumber, parsedSuccess], - [isString, parseStringtoNumberOrNull], - [isNull, parsedSuccess], - [defaultCase, parsedFailed], -); - -const options$2 = { - maxValue: { - defaultValue: Number.MAX_SAFE_INTEGER, - isValid: isSafeInteger, - requirementDescription: 'must be a valid integer', - parse: toNumberOrNull, - }, - minValue: { - defaultValue: 0 - Number.MAX_SAFE_INTEGER, - isValid: isSafeInteger, - requirementDescription: 'must be a valid integer', - parse: toNumberOrNull, - }, - decimalPlaces: { - defaultValue: 0, - isValid: n => isSafeInteger(n) && n >= 0, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, -}; - -const getDecimalPlaces = (val) => { - const splitDecimal = val.toString().split('.'); - if (splitDecimal.length === 1) return 0; - return splitDecimal[1].length; -}; - -const typeConstraints$2 = [ - makerule$1(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue, - (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`), - makerule$1(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue, - (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`), - makerule$1(async (val, opts) => val === null || opts.decimalPlaces >= getDecimalPlaces(val), - (val, opts) => `value (${val.toString()}) must have ${opts.decimalPlaces} decimal places or less`), -]; - -var number = getDefaultExport( - 'number', - numberTryParse, - numberFunctions, - options$2, - typeConstraints$2, - 1, - num => num.toString(), -); - -const dateFunctions = typeFunctions({ - default: constant(null), - now: () => new Date(), -}); - -const isValidDate = d => d instanceof Date && !isNaN(d); - -const parseStringToDate = s => switchCase( - [isValidDate, parsedSuccess], - [defaultCase, parsedFailed], -)(new Date(s)); - - -const dateTryParse = switchCase( - [isDate, parsedSuccess], - [isString, parseStringToDate], - [isNull, parsedSuccess], - [defaultCase, parsedFailed], -); - -const options$3 = { - maxValue: { - defaultValue: new Date(32503680000000), - isValid: isDate, - requirementDescription: 'must be a valid date', - parse: toDateOrNull, - }, - minValue: { - defaultValue: new Date(-8520336000000), - isValid: isDate, - requirementDescription: 'must be a valid date', - parse: toDateOrNull, - }, -}; - -const typeConstraints$3 = [ - makerule$1(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue, - (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`), - makerule$1(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue, - (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`), -]; - -var datetime = getDefaultExport( - 'datetime', - dateTryParse, - dateFunctions, - options$3, - typeConstraints$3, - new Date(1984, 4, 1), - date => JSON.stringify(date).replace(new RegExp('"', 'g'), ''), -); - -const arrayFunctions = () => typeFunctions({ - default: constant([]), -}); - -const mapToParsedArrary = type => $$( - map(i => type.safeParseValue(i)), - parsedSuccess, -); - -const arrayTryParse = type => switchCase( - [isArray$1, mapToParsedArrary(type)], - [defaultCase, parsedFailed], -); - -const typeName = type => `array<${type}>`; - - -const options$4 = { - maxLength: { - defaultValue: 10000, - isValid: isSafeInteger, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, - minLength: { - defaultValue: 0, - isValid: n => isSafeInteger(n) && n >= 0, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, -}; - -const typeConstraints$4 = [ - makerule$1(async (val, opts) => val === null || val.length >= opts.minLength, - (val, opts) => `must choose ${opts.minLength} or more options`), - makerule$1(async (val, opts) => val === null || val.length <= opts.maxLength, - (val, opts) => `cannot choose more than ${opts.maxLength} options`), -]; - -var array = type => getDefaultExport( - typeName(type.name), - arrayTryParse(type), - arrayFunctions(), - options$4, - typeConstraints$4, - [type.sampleValue], - JSON.stringify, -); - -const referenceNothing = () => ({ key: '' }); - -const referenceFunctions = typeFunctions({ - default: referenceNothing, -}); - -const hasStringValue = (ob, path) => has(path)(ob) - && isString(ob[path]); - -const isObjectWithKey = v => isObjectLike(v) - && hasStringValue(v, 'key'); - -const tryParseFromString = s => { - - try { - const asObj = JSON.parse(s); - if(isObjectWithKey) { - return parsedSuccess(asObj); - } - } - catch(_) { - // EMPTY - } - - return parsedFailed(s); -}; - -const referenceTryParse = v => switchCase( - [isObjectWithKey, parsedSuccess], - [isString, tryParseFromString], - [isNull, () => parsedSuccess(referenceNothing())], - [defaultCase, parsedFailed], -)(v); - -const options$5 = { - indexNodeKey: { - defaultValue: null, - isValid: isNonEmptyString, - requirementDescription: 'must be a non-empty string', - parse: s => s, - }, - displayValue: { - defaultValue: '', - isValid: isNonEmptyString, - requirementDescription: 'must be a non-empty string', - parse: s => s, - }, - reverseIndexNodeKeys: { - defaultValue: null, - isValid: v => isArrayOfString(v) && v.length > 0, - requirementDescription: 'must be a non-empty array of strings', - parse: s => s, - }, -}; - -const isEmptyString = s => isString(s) && isEmpty(s); - -const ensureReferenceExists = async (val, opts, context) => isEmptyString(val.key) - || await context.referenceExists(opts, val.key); - -const typeConstraints$5 = [ - makerule$1( - ensureReferenceExists, - (val, opts) => `"${val[opts.displayValue]}" does not exist in options list (key: ${val.key})`, - ), -]; - -var reference = getDefaultExport( - 'reference', - referenceTryParse, - referenceFunctions, - options$5, - typeConstraints$5, - { key: 'key', value: 'value' }, - JSON.stringify, -); - -const illegalCharacters = '*?\\/:<>|\0\b\f\v'; - -const isLegalFilename = (filePath) => { - const fn = fileName(filePath); - return fn.length <= 255 - && intersection(fn.split(''))(illegalCharacters.split('')).length === 0 - && none(f => f === '..')(splitKey(filePath)); -}; - -const fileNothing = () => ({ relativePath: '', size: 0 }); - -const fileFunctions = typeFunctions({ - default: fileNothing, -}); - -const fileTryParse = v => switchCase( - [isValidFile, parsedSuccess], - [isNull, () => parsedSuccess(fileNothing())], - [defaultCase, parsedFailed], -)(v); - -const fileName = filePath => $(filePath, [ - splitKey, - last, -]); - -const isValidFile = f => !isNull(f) - && has('relativePath')(f) && has('size')(f) - && isNumber(f.size) - && isString(f.relativePath) - && isLegalFilename(f.relativePath); - -const options$6 = {}; - -const typeConstraints$6 = []; - -var file = getDefaultExport( - 'file', - fileTryParse, - fileFunctions, - options$6, - typeConstraints$6, - { relativePath: 'some_file.jpg', size: 1000 }, - JSON.stringify, -); - -const allTypes = () => { - const basicTypes = { - string, number, datetime, bool, reference, file, - }; - - const arrays = $(basicTypes, [ - keys, - map((k) => { - const kvType = {}; - const concreteArray = array(basicTypes[k]); - kvType[concreteArray.name] = concreteArray; - return kvType; - }), - types => assign({}, ...types), - ]); - - return merge({}, basicTypes, arrays); -}; - - -const all$1 = allTypes(); - -const getType = (typeName) => { - if (!has(typeName)(all$1)) throw new BadRequestError(`Do not recognise type ${typeName}`); - return all$1[typeName]; -}; - -const getSampleFieldValue = field => getType(field.type).sampleValue; - -const getNewFieldValue = field => getType(field.type).getNew(field); - -const safeParseField = (field, record) => getType(field.type).safeParseField(field, record); - -const validateFieldParse = (field, record) => (has(field.name)(record) - ? getType(field.type).tryParse(record[field.name]) - : parsedSuccess(undefined)); // fields may be undefined by default - -const getDefaultOptions$1 = type => getType(type).getDefaultOptions(); - -const validateTypeConstraints$1 = async (field, record, context) => await getType(field.type).validateTypeConstraints(field, record, context); - -const detectType = (value) => { - if (isString(value)) return string; - if (isBoolean(value)) return bool; - if (isNumber(value)) return number; - if (isDate(value)) return datetime; - if (isArray$1(value)) return array(detectType(value[0])); - if (isObject(value) - && has('key')(value) - && has('value')(value)) return reference; - if (isObject(value) - && has('relativePath')(value) - && has('size')(value)) return file; - - throw new BadRequestError(`cannot determine type: ${JSON.stringify(value)}`); -}; - -// 5 minutes -const tempCodeExpiryLength = 5 * 60 * 1000; - -const AUTH_FOLDER = '/.auth'; -const USERS_LIST_FILE = joinKey(AUTH_FOLDER, 'users.json'); -const userAuthFile = username => joinKey(AUTH_FOLDER, `auth_${username}.json`); -const USERS_LOCK_FILE = joinKey(AUTH_FOLDER, 'users_lock'); -const ACCESS_LEVELS_FILE = joinKey(AUTH_FOLDER, 'access_levels.json'); -const ACCESS_LEVELS_LOCK_FILE = joinKey(AUTH_FOLDER, 'access_levels_lock'); - -const permissionTypes = { - CREATE_RECORD: 'create record', - UPDATE_RECORD: 'update record', - READ_RECORD: 'read record', - DELETE_RECORD: 'delete record', - READ_INDEX: 'read index', - MANAGE_INDEX: 'manage index', - MANAGE_COLLECTION: 'manage collection', - WRITE_TEMPLATES: 'write templates', - CREATE_USER: 'create user', - SET_PASSWORD: 'set password', - CREATE_TEMPORARY_ACCESS: 'create temporary access', - ENABLE_DISABLE_USER: 'enable or disable user', - WRITE_ACCESS_LEVELS: 'write access levels', - LIST_USERS: 'list users', - LIST_ACCESS_LEVELS: 'list access levels', - EXECUTE_ACTION: 'execute action', - SET_USER_ACCESS_LEVELS: 'set user access levels', -}; - -const getUserByName = (users, name) => $(users, [ - find(u => u.name.toLowerCase() === name.toLowerCase()), -]); - -const stripUserOfSensitiveStuff = (user) => { - const stripped = clone(user); - delete stripped.tempCode; - return stripped; -}; - -const parseTemporaryCode = fullCode => $(fullCode, [ - split(':'), - parts => ({ - id: parts[1], - code: parts[2], - }), -]); - -const isAuthorized = app => (permissionType, resourceKey) => apiWrapperSync( - app, - events.authApi.isAuthorized, - alwaysAuthorized, - { resourceKey, permissionType }, - _isAuthorized, app, permissionType, resourceKey, -); - -const _isAuthorized = (app, permissionType, resourceKey) => { - if (!app.user) { - return false; - } - - const validType = $(permissionTypes, [ - values, - includes(permissionType), - ]); - - if (!validType) { - return false; - } - - const permMatchesResource = (userperm) => { - const nodeKey = isNothing(resourceKey) - ? null - : isNode(app.hierarchy, resourceKey) - ? getNodeByKeyOrNodeKey( - app.hierarchy, resourceKey, - ).nodeKey() - : resourceKey; - - return (userperm.type === permissionType) - && ( - isNothing(resourceKey) - || nodeKey === userperm.nodeKey - ); - }; - - return $(app.user.permissions, [ - some(permMatchesResource), - ]); -}; - -const nodePermission = type => ({ - add: (nodeKey, accessLevel) => accessLevel.permissions.push({ type, nodeKey }), - isAuthorized: resourceKey => app => isAuthorized(app)(type, resourceKey), - isNode: true, - get: nodeKey => ({ type, nodeKey }), -}); - -const staticPermission = type => ({ - add: accessLevel => accessLevel.permissions.push({ type }), - isAuthorized: app => isAuthorized(app)(type), - isNode: false, - get: () => ({ type }), -}); - -const createRecord = nodePermission(permissionTypes.CREATE_RECORD); - -const updateRecord = nodePermission(permissionTypes.UPDATE_RECORD); - -const deleteRecord = nodePermission(permissionTypes.DELETE_RECORD); - -const readRecord = nodePermission(permissionTypes.READ_RECORD); - -const writeTemplates = staticPermission(permissionTypes.WRITE_TEMPLATES); - -const createUser = staticPermission(permissionTypes.CREATE_USER); - -const setPassword = staticPermission(permissionTypes.SET_PASSWORD); - -const readIndex = nodePermission(permissionTypes.READ_INDEX); - -const manageIndex = staticPermission(permissionTypes.MANAGE_INDEX); - -const manageCollection = staticPermission(permissionTypes.MANAGE_COLLECTION); - -const createTemporaryAccess = staticPermission(permissionTypes.CREATE_TEMPORARY_ACCESS); - -const enableDisableUser = staticPermission(permissionTypes.ENABLE_DISABLE_USER); - -const writeAccessLevels = staticPermission(permissionTypes.WRITE_ACCESS_LEVELS); - -const listUsers = staticPermission(permissionTypes.LIST_USERS); - -const listAccessLevels = staticPermission(permissionTypes.LIST_ACCESS_LEVELS); - -const setUserAccessLevels = staticPermission(permissionTypes.SET_USER_ACCESS_LEVELS); - -const executeAction = nodePermission(permissionTypes.EXECUTE_ACTION); - -const alwaysAuthorized = () => true; - -const permission = { - createRecord, - updateRecord, - deleteRecord, - readRecord, - writeTemplates, - createUser, - setPassword, - readIndex, - createTemporaryAccess, - enableDisableUser, - writeAccessLevels, - listUsers, - listAccessLevels, - manageIndex, - manageCollection, - executeAction, - setUserAccessLevels, -}; - -const getNew = app => (collectionKey, recordTypeName) => { - const recordNode = getRecordNode(app, collectionKey); - collectionKey=safeKey(collectionKey); - return apiWrapperSync( - app, - events.recordApi.getNew, - permission.createRecord.isAuthorized(recordNode.nodeKey()), - { collectionKey, recordTypeName }, - _getNew, recordNode, collectionKey, - ); -}; - -const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey); - -const getRecordNode = (app, collectionKey) => { - collectionKey = safeKey(collectionKey); - return getNodeForCollectionPath(app.hierarchy)(collectionKey); -}; - -const getNewChild = app => (recordKey, collectionName, recordTypeName) => - getNew(app)(joinKey(recordKey, collectionName), recordTypeName); - -const constructRecord = (recordNode, getFieldValue, collectionKey) => { - const record = $(recordNode.fields, [ - keyBy('name'), - mapValues(getFieldValue), - ]); - - record.id = `${recordNode.nodeId}-${generate()}`; - record.key = isSingleRecord(recordNode) - ? joinKey(collectionKey, recordNode.name) - : joinKey(collectionKey, record.id); - record.isNew = true; - record.type = recordNode.name; - return record; -}; - -const allIdChars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_-'; - -// this should never be changed - ever -// - existing databases depend on the order of chars this string - -/** - * folderStructureArray should return an array like - * - [1] = all records fit into one folder - * - [2] = all records fite into 2 folders - * - [64, 3] = all records fit into 64 * 3 folders - * - [64, 64, 10] = all records fit into 64 * 64 * 10 folder - * (there are 64 possible chars in allIsChars) -*/ -const folderStructureArray = (recordNode) => { - - const totalFolders = Math.ceil(recordNode.estimatedRecordCount / 1000); - const folderArray = []; - let levelCount = 1; - while(64**levelCount < totalFolders) { - levelCount += 1; - folderArray.push(64); - } - - const parentFactor = (64**folderArray.length); - if(parentFactor < totalFolders) { - folderArray.push( - Math.ceil(totalFolders / parentFactor) - ); - } - - return folderArray; - - /* - const maxRecords = currentFolderPosition === 0 - ? RECORDS_PER_FOLDER - : currentFolderPosition * 64 * RECORDS_PER_FOLDER; - - if(maxRecords < recordNode.estimatedRecordCount) { - return folderStructureArray( - recordNode, - [...currentArray, 64], - currentFolderPosition + 1); - } else { - const childFolderCount = Math.ceil(recordNode.estimatedRecordCount / maxRecords ); - return [...currentArray, childFolderCount] - }*/ -}; - - -const getAllIdsIterator = app => async (collection_Key_or_NodeKey) => { - collection_Key_or_NodeKey = safeKey(collection_Key_or_NodeKey); - const recordNode = getCollectionNodeByKeyOrNodeKey( - app.hierarchy, - collection_Key_or_NodeKey, - ); - - const getAllIdsIteratorForCollectionKey = async (recordNode, collectionKey) => { - - const folderStructure = folderStructureArray(recordNode); - - let currentFolderContents = []; - let currentPosition = []; - - const collectionDir = getCollectionDir(app.hierarchy, collectionKey); - const basePath = joinKey( - collectionDir, recordNode.nodeId.toString()); - - - - // "folderStructure" determines the top, sharding folders - // we need to add one, for the collection root folder, which - // always exists - const levels = folderStructure.length + 1; - const topLevel = levels -1; - - - /* populate initial directory structure in form: - [ - {path: "/a", contents: ["b", "c", "d"]}, - {path: "/a/b", contents: ["e","f","g"]}, - {path: "/a/b/e", contents: ["1-abcd","2-cdef","3-efgh"]}, - ] - // stores contents on each parent level - // top level has ID folders - */ - const firstFolder = async () => { - - let folderLevel = 0; - - const lastPathHasContent = () => - folderLevel === 0 - || currentFolderContents[folderLevel - 1].contents.length > 0; - - - while (folderLevel <= topLevel && lastPathHasContent()) { - - let thisPath = basePath; - for(let lev = 0; lev < currentPosition.length; lev++) { - thisPath = joinKey( - thisPath, currentFolderContents[lev].contents[0]); - } - - const contentsThisLevel = - await app.datastore.getFolderContents(thisPath); - currentFolderContents.push({ - contents:contentsThisLevel, - path: thisPath - }); - - // should start as something like [0,0] - if(folderLevel < topLevel) - currentPosition.push(0); - - folderLevel+=1; - } - - return (currentPosition.length === levels - 1); - }; - - const isOnLastFolder = level => { - - const result = currentPosition[level] === currentFolderContents[level].contents.length - 1; - return result; - }; - - const getNextFolder = async (lev=undefined) => { - lev = isUndefined(lev) ? topLevel : lev; - const parentLev = lev - 1; - - if(parentLev < 0) return false; - - if(isOnLastFolder(parentLev)) { - return await getNextFolder(parentLev); - } - - const newPosition = currentPosition[parentLev] + 1; - currentPosition[parentLev] = newPosition; - - const nextFolder = joinKey( - currentFolderContents[parentLev].path, - currentFolderContents[parentLev].contents[newPosition]); - currentFolderContents[lev].contents = await app.datastore.getFolderContents( - nextFolder - ); - currentFolderContents[lev].path = nextFolder; - - if(lev !== topLevel) { - - // we just advanced a parent folder, so now need to - // do the same to the next levels - let loopLevel = lev + 1; - while(loopLevel <= topLevel) { - const loopParentLevel = loopLevel-1; - - currentPosition[loopParentLevel] = 0; - const nextLoopFolder = joinKey( - currentFolderContents[loopParentLevel].path, - currentFolderContents[loopParentLevel].contents[0]); - currentFolderContents[loopLevel].contents = await app.datastore.getFolderContents( - nextLoopFolder - ); - currentFolderContents[loopLevel].path = nextLoopFolder; - loopLevel+=1; - } - } - - // true ==has more ids... (just loaded more) - return true; - }; - - - const idsCurrentFolder = () => - currentFolderContents[currentFolderContents.length - 1].contents; - - const fininshedResult = ({ done: true, result: { ids: [], collectionKey } }); - - let hasStarted = false; - let hasMore = true; - const getIdsFromCurrentfolder = async () => { - - if(!hasMore) { - return fininshedResult; - } - - if(!hasStarted) { - hasMore = await firstFolder(); - hasStarted = true; - return ({ - result: { - ids: idsCurrentFolder(), - collectionKey - }, - done: false - }) - } - - hasMore = await getNextFolder(); - - return ({ - result: { - ids: hasMore ? idsCurrentFolder() : [], - collectionKey - }, - done: !hasMore - }); - }; - - return getIdsFromCurrentfolder; - - }; - - const ancestors = $(getFlattenedHierarchy(app.hierarchy), [ - filter(isCollectionRecord), - filter(n => isAncestor(recordNode)(n) - || n.nodeKey() === recordNode.nodeKey()), - orderBy([n => n.nodeKey().length], ['asc']), - ]); // parents first - - const traverseForIteraterators = async (parentRecordKey = '', currentNodeIndex = 0) => { - const currentNode = ancestors[currentNodeIndex]; - const currentCollectionKey = joinKey( - parentRecordKey, - currentNode.collectionName, - ); - if (currentNode.nodeKey() === recordNode.nodeKey()) { - return [ - await getAllIdsIteratorForCollectionKey( - currentNode, - currentCollectionKey, - )]; - } - const allIterators = []; - const currentIterator = await getAllIdsIteratorForCollectionKey( - currentNode, - currentCollectionKey, - ); - - let ids = await currentIterator(); - while (ids.done === false) { - for (const id of ids.result.ids) { - allIterators.push( - await traverseForIteraterators( - joinKey(currentCollectionKey, id), - currentNodeIndex + 1, - ), - ); - } - - ids = await currentIterator(); - } - - return flatten(allIterators); - }; - - const iteratorsArray = await traverseForIteraterators(); - let currentIteratorIndex = 0; - return async () => { - if (iteratorsArray.length === 0) { return { done: true, result: [] }; } - const innerResult = await iteratorsArray[currentIteratorIndex](); - if (!innerResult.done) { return innerResult; } - if (currentIteratorIndex == iteratorsArray.length - 1) { - return { done: true, result: innerResult.result }; - } - currentIteratorIndex++; - return { done: false, result: innerResult.result }; - }; -}; - -const getRecordInfo = (hierarchy, key) => { - const recordNode = getExactNodeForKey(hierarchy)(key); - const pathInfo = getRecordDirectory(recordNode, key); - const dir = joinKey(pathInfo.base, ...pathInfo.subdirs); - - return { - recordJson: recordJson(dir), - files: files(dir), - child:(name) => joinKey(dir, name), - key: safeKey(key), - recordNode, pathInfo, dir - }; -}; - -const getCollectionDir = (hierarchy, collectionKey) => { - const recordNode = getNodeForCollectionPath(hierarchy)(collectionKey); - const dummyRecordKey = joinKey(collectionKey, "1-abcd"); - const pathInfo = getRecordDirectory(recordNode, dummyRecordKey); - return pathInfo.base; -}; - -const recordJson = (dir) => - joinKey(dir, "record.json"); - -const files = (dir) => - joinKey(dir, "files"); - -const getRecordDirectory = (recordNode, key) => { - const id = getFileFromKey(key); - - const traverseParentKeys = (n, parents=[]) => { - if(isRoot(n)) return parents; - const k = getActualKeyOfParent(n.nodeKey(), key); - const thisNodeDir = { - node:n, - relativeDir: joinKey( - recordRelativeDirectory(n, getFileFromKey(k))) - }; - return traverseParentKeys( - n.parent(), - [thisNodeDir, ...parents]); - }; - - const parentDirs = $(recordNode.parent(), [ - traverseParentKeys, - reduce((key, item) => { - return joinKey(key, item.node.collectionName, item.relativeDir) - }, keySep) - ]); - - const subdirs = isSingleRecord(recordNode) - ? [] - : recordRelativeDirectory(recordNode, id); - const base = isSingleRecord(recordNode) - ? joinKey(parentDirs, recordNode.name) - : joinKey(parentDirs, recordNode.collectionName); - - return ({ - subdirs, base - }); -}; - -const recordRelativeDirectory = (recordNode, id) => { - const folderStructure = folderStructureArray(recordNode); - const strippedId = id.substring(recordNode.nodeId.toString().length + 1); - const subfolders = $(folderStructure, [ - reduce((result, currentCount) => { - result.folders.push( - folderForChar(strippedId[result.level], currentCount) - ); - return {level:result.level+1, folders:result.folders}; - }, {level:0, folders:[]}), - f => f.folders, - filter(f => !!f) - ]); - - return [recordNode.nodeId.toString(), ...subfolders, id] -}; - -const folderForChar = (char, folderCount) => - folderCount === 1 ? "" - : $(folderCount, [ - idFoldersForFolderCount, - find(f => f.includes(char)) - ]); - -const idFoldersForFolderCount = (folderCount) => { - const charRangePerShard = 64 / folderCount; - const idFolders = []; - let index = 0; - let currentIdsShard = ''; - while (index < 64) { - currentIdsShard += allIdChars[index]; - if ((index + 1) % charRangePerShard === 0) { - idFolders.push(currentIdsShard); - currentIdsShard = ''; - } - index++; - } - - return idFolders; -}; - -const load = app => async key => { - key = safeKey(key); - return apiWrapper( - app, - events.recordApi.load, - permission.readRecord.isAuthorized(key), - { key }, - _load, app, key, - ); -}; - -const _loadFromInfo = async (app, recordInfo, keyStack = []) => { - const key = recordInfo.key; - const {recordNode, recordJson} = recordInfo; - const storedData = await app.datastore.loadJson(recordJson); - - const loadedRecord = $(recordNode.fields, [ - keyBy('name'), - mapValues(f => safeParseField(f, storedData)), - ]); - - const newKeyStack = [...keyStack, key]; - - const references = $(recordNode.fields, [ - filter(f => f.type === 'reference' - && isNonEmptyString(loadedRecord[f.name].key) - && !includes(loadedRecord[f.name].key)(newKeyStack)), - map(f => ({ - promise: _load(app, loadedRecord[f.name].key, newKeyStack), - index: getNode(app.hierarchy, f.typeOptions.indexNodeKey), - field: f, - })), - ]); - - if (references.length > 0) { - const refRecords = await Promise.all( - map(p => p.promise)(references), - ); - - for (const ref of references) { - loadedRecord[ref.field.name] = mapRecord( - refRecords[references.indexOf(ref)], - ref.index, - ); - } - } - - loadedRecord.transactionId = storedData.transactionId; - loadedRecord.isNew = false; - loadedRecord.key = key; - loadedRecord.id = $(key, [splitKey, last]); - loadedRecord.type = recordNode.name; - return loadedRecord; -}; - -const _load = async (app, key, keyStack = []) => - _loadFromInfo( - app, - getRecordInfo(app.hierarchy, key), - keyStack); - -// adapted from https://github.com/dex4er/js-promise-readable -// thanks :) - -const promiseReadableStream = stream => { - - let _errored; - - const _errorHandler = err => { - _errored = err; - }; - - stream.on("error", _errorHandler); - - const read = (size) => { - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err) - } - - if (!stream.readable || stream.closed || stream.destroyed) { - return resolve(); - } - - const readableHandler = () => { - const chunk = stream.read(size); - - if (chunk) { - removeListeners(); - resolve(chunk); - } - }; - - const closeHandler = () => { - removeListeners(); - resolve(); - }; - - const endHandler = () => { - removeListeners(); - resolve(); - }; - - const errorHandler = (err) => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const removeListeners = () => { - stream.removeListener("close", closeHandler); - stream.removeListener("error", errorHandler); - stream.removeListener("end", endHandler); - stream.removeListener("readable", readableHandler); - }; - - stream.on("close", closeHandler); - stream.on("end", endHandler); - stream.on("error", errorHandler); - stream.on("readable", readableHandler); - - readableHandler(); - }); - }; - - - const destroy = () => { - if (stream) { - if (_errorHandler) { - stream.removeListener("error", _errorHandler); - } - if (typeof stream.destroy === "function") { - stream.destroy(); - } - } - }; - - return {read, destroy, stream}; - }; - -const getIndexedDataKey = (indexNode, indexDir, record) => { - - const getShardName = (indexNode, record) => { - const shardNameFunc = compileCode$1(indexNode.getShardName); - try { - return shardNameFunc({ record }); - } catch(e) { - const errorDetails = `shardCode: ${indexNode.getShardName} :: record: ${JSON.stringify(record)} :: `; - e.message = "Error running index shardname func: " + errorDetails + e.message; - throw e; - } - }; - - const shardName = isNonEmptyString(indexNode.getShardName) - ? `${getShardName(indexNode, record)}.csv` - : 'index.csv'; - - return joinKey(indexDir, shardName); -}; - -const getShardKeysInRange = async (app, indexNode, indexDir, startRecord = null, endRecord = null) => { - const startShardName = !startRecord - ? null - : shardNameFromKey( - getIndexedDataKey( - indexNode, - indexDir, - startRecord, - ), - ); - - const endShardName = !endRecord - ? null - : shardNameFromKey( - getIndexedDataKey( - indexNode, - indexDir, - endRecord, - ), - ); - - return $(await getShardMap(app.datastore, indexDir), [ - filter(k => (startRecord === null || k >= startShardName) - && (endRecord === null || k <= endShardName)), - map(k => joinKey(indexDir, `${k}.csv`)), - ]); -}; - -const ensureShardNameIsInShardMap = async (store, indexDir, indexedDataKey) => { - const map = await getShardMap(store, indexDir); - const shardName = shardNameFromKey(indexedDataKey); - if (!includes(shardName)(map)) { - map.push(shardName); - await writeShardMap(store, indexDir, map); - } -}; - -const getShardMap = async (datastore, indexDir) => { - const shardMapKey = getShardMapKey(indexDir); - try { - return await datastore.loadJson(shardMapKey); - } catch (_) { - await datastore.createJson(shardMapKey, []); - return []; - } -}; - -const writeShardMap = async (datastore, indexDir, shardMap) => await datastore.updateJson( - getShardMapKey(indexDir), - shardMap, -); - -const getShardMapKey = indexDir => joinKey(indexDir, 'shardMap.json'); - -const getUnshardedIndexDataKey = indexDir => joinKey(indexDir, 'index.csv'); - -const createIndexFile = async (datastore, indexedDataKey, index) => { - if (isShardedIndex(index)) { - const indexDir = getParentKey(indexedDataKey); - const shardMap = await getShardMap(datastore, indexDir); - shardMap.push( - shardNameFromKey(indexedDataKey), - ); - await writeShardMap(datastore, indexDir, shardMap); - } - await datastore.createFile(indexedDataKey, ''); -}; - -const shardNameFromKey = key => $(key, [ - splitKey, - last, -]).replace('.csv', ''); - -const getIndexKey_BasedOnDecendant = (decendantKey, indexNode) => { - if (isGlobalIndex(indexNode)) { return `${indexNode.nodeKey()}`; } - - const indexedDataParentKey = getActualKeyOfParent( - indexNode.parent().nodeKey(), - decendantKey, - ); - - return joinKey( - indexedDataParentKey, - indexNode.name, - ); -}; - -const generateSchema = (hierarchy, indexNode) => { - const recordNodes = getAllowedRecordNodesForIndex(hierarchy, indexNode); - const mappedRecords = $(recordNodes, [ - map(n => mapRecord(createSampleRecord(n), indexNode)), - ]); - - // always has record key and sort key - const schema = { - sortKey: all$1.string, - key: all$1.string, - }; - - const fieldsHas = has(schema); - const setField = (fieldName, value) => { - if (value === null || value === undefined) { return; } - - const thisType = detectType(value); - if (fieldsHas(fieldName)) { - if (schema[fieldName] !== thisType) { - schema[fieldName] = all$1.string; - } - } else { - schema[fieldName] = thisType; - } - }; - - for (const mappedRec of mappedRecords) { - for (const f in mappedRec) { - setField(f, mappedRec[f]); - } - } - - // returing an array of {name, type} - return $(schema, [ - keys, - map(k => ({ name: k, type: schema[k].name })), - filter(s => s.name !== 'sortKey'), - orderBy('name', ['desc']), // reverse aplha - concat([{ name: 'sortKey', type: all$1.string.name }]), // sortKey on end - reverse, // sortKey first, then rest are alphabetical - ]); -}; - -const createSampleRecord = recordNode => constructRecord( - recordNode, - getSampleFieldValue, - recordNode.parent().nodeKey(), -); - -var global$1 = (typeof global !== "undefined" ? global : - typeof self !== "undefined" ? self : - typeof window !== "undefined" ? window : {}); - -var lookup = []; -var revLookup = []; -var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array; -var inited = false; -function init () { - inited = true; - var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; - for (var i = 0, len = code.length; i < len; ++i) { - lookup[i] = code[i]; - revLookup[code.charCodeAt(i)] = i; - } - - revLookup['-'.charCodeAt(0)] = 62; - revLookup['_'.charCodeAt(0)] = 63; -} - -function toByteArray (b64) { - if (!inited) { - init(); - } - var i, j, l, tmp, placeHolders, arr; - var len = b64.length; - - if (len % 4 > 0) { - throw new Error('Invalid string. Length must be a multiple of 4') - } - - // the number of equal signs (place holders) - // if there are two placeholders, than the two characters before it - // represent one byte - // if there is only one, then the three characters before it represent 2 bytes - // this is just a cheap hack to not do indexOf twice - placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0; - - // base64 is 4/3 + up to two characters of the original data - arr = new Arr(len * 3 / 4 - placeHolders); - - // if there are placeholders, only get up to the last complete 4 chars - l = placeHolders > 0 ? len - 4 : len; - - var L = 0; - - for (i = 0, j = 0; i < l; i += 4, j += 3) { - tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]; - arr[L++] = (tmp >> 16) & 0xFF; - arr[L++] = (tmp >> 8) & 0xFF; - arr[L++] = tmp & 0xFF; - } - - if (placeHolders === 2) { - tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4); - arr[L++] = tmp & 0xFF; - } else if (placeHolders === 1) { - tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2); - arr[L++] = (tmp >> 8) & 0xFF; - arr[L++] = tmp & 0xFF; - } - - return arr -} - -function tripletToBase64 (num) { - return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F] -} - -function encodeChunk (uint8, start, end) { - var tmp; - var output = []; - for (var i = start; i < end; i += 3) { - tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2]); - output.push(tripletToBase64(tmp)); - } - return output.join('') -} - -function fromByteArray (uint8) { - if (!inited) { - init(); - } - var tmp; - var len = uint8.length; - var extraBytes = len % 3; // if we have 1 byte left, pad 2 bytes - var output = ''; - var parts = []; - var maxChunkLength = 16383; // must be multiple of 3 - - // go through the array every three bytes, we'll deal with trailing stuff later - for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) { - parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength))); - } - - // pad the end with zeros, but make sure to not forget the extra bytes - if (extraBytes === 1) { - tmp = uint8[len - 1]; - output += lookup[tmp >> 2]; - output += lookup[(tmp << 4) & 0x3F]; - output += '=='; - } else if (extraBytes === 2) { - tmp = (uint8[len - 2] << 8) + (uint8[len - 1]); - output += lookup[tmp >> 10]; - output += lookup[(tmp >> 4) & 0x3F]; - output += lookup[(tmp << 2) & 0x3F]; - output += '='; - } - - parts.push(output); - - return parts.join('') -} - -function read (buffer, offset, isLE, mLen, nBytes) { - var e, m; - var eLen = nBytes * 8 - mLen - 1; - var eMax = (1 << eLen) - 1; - var eBias = eMax >> 1; - var nBits = -7; - var i = isLE ? (nBytes - 1) : 0; - var d = isLE ? -1 : 1; - var s = buffer[offset + i]; - - i += d; - - e = s & ((1 << (-nBits)) - 1); - s >>= (-nBits); - nBits += eLen; - for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {} - - m = e & ((1 << (-nBits)) - 1); - e >>= (-nBits); - nBits += mLen; - for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {} - - if (e === 0) { - e = 1 - eBias; - } else if (e === eMax) { - return m ? NaN : ((s ? -1 : 1) * Infinity) - } else { - m = m + Math.pow(2, mLen); - e = e - eBias; - } - return (s ? -1 : 1) * m * Math.pow(2, e - mLen) -} - -function write (buffer, value, offset, isLE, mLen, nBytes) { - var e, m, c; - var eLen = nBytes * 8 - mLen - 1; - var eMax = (1 << eLen) - 1; - var eBias = eMax >> 1; - var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0); - var i = isLE ? 0 : (nBytes - 1); - var d = isLE ? 1 : -1; - var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0; - - value = Math.abs(value); - - if (isNaN(value) || value === Infinity) { - m = isNaN(value) ? 1 : 0; - e = eMax; - } else { - e = Math.floor(Math.log(value) / Math.LN2); - if (value * (c = Math.pow(2, -e)) < 1) { - e--; - c *= 2; - } - if (e + eBias >= 1) { - value += rt / c; - } else { - value += rt * Math.pow(2, 1 - eBias); - } - if (value * c >= 2) { - e++; - c /= 2; - } - - if (e + eBias >= eMax) { - m = 0; - e = eMax; - } else if (e + eBias >= 1) { - m = (value * c - 1) * Math.pow(2, mLen); - e = e + eBias; - } else { - m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen); - e = 0; - } - } - - for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} - - e = (e << mLen) | m; - eLen += mLen; - for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} - - buffer[offset + i - d] |= s * 128; -} - -var toString = {}.toString; - -var isArray = Array.isArray || function (arr) { - return toString.call(arr) == '[object Array]'; -}; - -var INSPECT_MAX_BYTES = 50; - -/** - * If `Buffer.TYPED_ARRAY_SUPPORT`: - * === true Use Uint8Array implementation (fastest) - * === false Use Object implementation (most compatible, even IE6) - * - * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, - * Opera 11.6+, iOS 4.2+. - * - * Due to various browser bugs, sometimes the Object implementation will be used even - * when the browser supports typed arrays. - * - * Note: - * - * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances, - * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438. - * - * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function. - * - * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of - * incorrect length in some situations. - - * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they - * get the Object implementation, which is slower but behaves correctly. - */ -Buffer.TYPED_ARRAY_SUPPORT = global$1.TYPED_ARRAY_SUPPORT !== undefined - ? global$1.TYPED_ARRAY_SUPPORT - : true; - -function kMaxLength () { - return Buffer.TYPED_ARRAY_SUPPORT - ? 0x7fffffff - : 0x3fffffff -} - -function createBuffer (that, length) { - if (kMaxLength() < length) { - throw new RangeError('Invalid typed array length') - } - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - that = new Uint8Array(length); - that.__proto__ = Buffer.prototype; - } else { - // Fallback: Return an object instance of the Buffer class - if (that === null) { - that = new Buffer(length); - } - that.length = length; - } - - return that -} - -/** - * The Buffer constructor returns instances of `Uint8Array` that have their - * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of - * `Uint8Array`, so the returned instances will have all the node `Buffer` methods - * and the `Uint8Array` methods. Square bracket notation works as expected -- it - * returns a single octet. - * - * The `Uint8Array` prototype remains unmodified. - */ - -function Buffer (arg, encodingOrOffset, length) { - if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) { - return new Buffer(arg, encodingOrOffset, length) - } - - // Common case. - if (typeof arg === 'number') { - if (typeof encodingOrOffset === 'string') { - throw new Error( - 'If encoding is specified then the first argument must be a string' - ) - } - return allocUnsafe(this, arg) - } - return from(this, arg, encodingOrOffset, length) -} - -Buffer.poolSize = 8192; // not used by this implementation - -// TODO: Legacy, not needed anymore. Remove in next major version. -Buffer._augment = function (arr) { - arr.__proto__ = Buffer.prototype; - return arr -}; - -function from (that, value, encodingOrOffset, length) { - if (typeof value === 'number') { - throw new TypeError('"value" argument must not be a number') - } - - if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) { - return fromArrayBuffer(that, value, encodingOrOffset, length) - } - - if (typeof value === 'string') { - return fromString(that, value, encodingOrOffset) - } - - return fromObject(that, value) -} - -/** - * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError - * if value is a number. - * Buffer.from(str[, encoding]) - * Buffer.from(array) - * Buffer.from(buffer) - * Buffer.from(arrayBuffer[, byteOffset[, length]]) - **/ -Buffer.from = function (value, encodingOrOffset, length) { - return from(null, value, encodingOrOffset, length) -}; - -if (Buffer.TYPED_ARRAY_SUPPORT) { - Buffer.prototype.__proto__ = Uint8Array.prototype; - Buffer.__proto__ = Uint8Array; -} - -function assertSize (size) { - if (typeof size !== 'number') { - throw new TypeError('"size" argument must be a number') - } else if (size < 0) { - throw new RangeError('"size" argument must not be negative') - } -} - -function alloc (that, size, fill, encoding) { - assertSize(size); - if (size <= 0) { - return createBuffer(that, size) - } - if (fill !== undefined) { - // Only pay attention to encoding if it's a string. This - // prevents accidentally sending in a number that would - // be interpretted as a start offset. - return typeof encoding === 'string' - ? createBuffer(that, size).fill(fill, encoding) - : createBuffer(that, size).fill(fill) - } - return createBuffer(that, size) -} - -/** - * Creates a new filled Buffer instance. - * alloc(size[, fill[, encoding]]) - **/ -Buffer.alloc = function (size, fill, encoding) { - return alloc(null, size, fill, encoding) -}; - -function allocUnsafe (that, size) { - assertSize(size); - that = createBuffer(that, size < 0 ? 0 : checked(size) | 0); - if (!Buffer.TYPED_ARRAY_SUPPORT) { - for (var i = 0; i < size; ++i) { - that[i] = 0; - } - } - return that -} - -/** - * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance. - * */ -Buffer.allocUnsafe = function (size) { - return allocUnsafe(null, size) -}; -/** - * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance. - */ -Buffer.allocUnsafeSlow = function (size) { - return allocUnsafe(null, size) -}; - -function fromString (that, string, encoding) { - if (typeof encoding !== 'string' || encoding === '') { - encoding = 'utf8'; - } - - if (!Buffer.isEncoding(encoding)) { - throw new TypeError('"encoding" must be a valid string encoding') - } - - var length = byteLength(string, encoding) | 0; - that = createBuffer(that, length); - - var actual = that.write(string, encoding); - - if (actual !== length) { - // Writing a hex string, for example, that contains invalid characters will - // cause everything after the first invalid character to be ignored. (e.g. - // 'abxxcd' will be treated as 'ab') - that = that.slice(0, actual); - } - - return that -} - -function fromArrayLike (that, array) { - var length = array.length < 0 ? 0 : checked(array.length) | 0; - that = createBuffer(that, length); - for (var i = 0; i < length; i += 1) { - that[i] = array[i] & 255; - } - return that -} - -function fromArrayBuffer (that, array, byteOffset, length) { - array.byteLength; // this throws if `array` is not a valid ArrayBuffer - - if (byteOffset < 0 || array.byteLength < byteOffset) { - throw new RangeError('\'offset\' is out of bounds') - } - - if (array.byteLength < byteOffset + (length || 0)) { - throw new RangeError('\'length\' is out of bounds') - } - - if (byteOffset === undefined && length === undefined) { - array = new Uint8Array(array); - } else if (length === undefined) { - array = new Uint8Array(array, byteOffset); - } else { - array = new Uint8Array(array, byteOffset, length); - } - - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - that = array; - that.__proto__ = Buffer.prototype; - } else { - // Fallback: Return an object instance of the Buffer class - that = fromArrayLike(that, array); - } - return that -} - -function fromObject (that, obj) { - if (internalIsBuffer(obj)) { - var len = checked(obj.length) | 0; - that = createBuffer(that, len); - - if (that.length === 0) { - return that - } - - obj.copy(that, 0, 0, len); - return that - } - - if (obj) { - if ((typeof ArrayBuffer !== 'undefined' && - obj.buffer instanceof ArrayBuffer) || 'length' in obj) { - if (typeof obj.length !== 'number' || isnan(obj.length)) { - return createBuffer(that, 0) - } - return fromArrayLike(that, obj) - } - - if (obj.type === 'Buffer' && isArray(obj.data)) { - return fromArrayLike(that, obj.data) - } - } - - throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.') -} - -function checked (length) { - // Note: cannot use `length < kMaxLength()` here because that fails when - // length is NaN (which is otherwise coerced to zero.) - if (length >= kMaxLength()) { - throw new RangeError('Attempt to allocate Buffer larger than maximum ' + - 'size: 0x' + kMaxLength().toString(16) + ' bytes') - } - return length | 0 -} -Buffer.isBuffer = isBuffer; -function internalIsBuffer (b) { - return !!(b != null && b._isBuffer) -} - -Buffer.compare = function compare (a, b) { - if (!internalIsBuffer(a) || !internalIsBuffer(b)) { - throw new TypeError('Arguments must be Buffers') - } - - if (a === b) return 0 - - var x = a.length; - var y = b.length; - - for (var i = 0, len = Math.min(x, y); i < len; ++i) { - if (a[i] !== b[i]) { - x = a[i]; - y = b[i]; - break - } - } - - if (x < y) return -1 - if (y < x) return 1 - return 0 -}; - -Buffer.isEncoding = function isEncoding (encoding) { - switch (String(encoding).toLowerCase()) { - case 'hex': - case 'utf8': - case 'utf-8': - case 'ascii': - case 'latin1': - case 'binary': - case 'base64': - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return true - default: - return false - } -}; - -Buffer.concat = function concat (list, length) { - if (!isArray(list)) { - throw new TypeError('"list" argument must be an Array of Buffers') - } - - if (list.length === 0) { - return Buffer.alloc(0) - } - - var i; - if (length === undefined) { - length = 0; - for (i = 0; i < list.length; ++i) { - length += list[i].length; - } - } - - var buffer = Buffer.allocUnsafe(length); - var pos = 0; - for (i = 0; i < list.length; ++i) { - var buf = list[i]; - if (!internalIsBuffer(buf)) { - throw new TypeError('"list" argument must be an Array of Buffers') - } - buf.copy(buffer, pos); - pos += buf.length; - } - return buffer -}; - -function byteLength (string, encoding) { - if (internalIsBuffer(string)) { - return string.length - } - if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' && - (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) { - return string.byteLength - } - if (typeof string !== 'string') { - string = '' + string; - } - - var len = string.length; - if (len === 0) return 0 - - // Use a for loop to avoid recursion - var loweredCase = false; - for (;;) { - switch (encoding) { - case 'ascii': - case 'latin1': - case 'binary': - return len - case 'utf8': - case 'utf-8': - case undefined: - return utf8ToBytes(string).length - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return len * 2 - case 'hex': - return len >>> 1 - case 'base64': - return base64ToBytes(string).length - default: - if (loweredCase) return utf8ToBytes(string).length // assume utf8 - encoding = ('' + encoding).toLowerCase(); - loweredCase = true; - } - } -} -Buffer.byteLength = byteLength; - -function slowToString (encoding, start, end) { - var loweredCase = false; - - // No need to verify that "this.length <= MAX_UINT32" since it's a read-only - // property of a typed array. - - // This behaves neither like String nor Uint8Array in that we set start/end - // to their upper/lower bounds if the value passed is out of range. - // undefined is handled specially as per ECMA-262 6th Edition, - // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization. - if (start === undefined || start < 0) { - start = 0; - } - // Return early if start > this.length. Done here to prevent potential uint32 - // coercion fail below. - if (start > this.length) { - return '' - } - - if (end === undefined || end > this.length) { - end = this.length; - } - - if (end <= 0) { - return '' - } - - // Force coersion to uint32. This will also coerce falsey/NaN values to 0. - end >>>= 0; - start >>>= 0; - - if (end <= start) { - return '' - } - - if (!encoding) encoding = 'utf8'; - - while (true) { - switch (encoding) { - case 'hex': - return hexSlice(this, start, end) - - case 'utf8': - case 'utf-8': - return utf8Slice(this, start, end) - - case 'ascii': - return asciiSlice(this, start, end) - - case 'latin1': - case 'binary': - return latin1Slice(this, start, end) - - case 'base64': - return base64Slice(this, start, end) - - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return utf16leSlice(this, start, end) - - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = (encoding + '').toLowerCase(); - loweredCase = true; - } - } -} - -// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect -// Buffer instances. -Buffer.prototype._isBuffer = true; - -function swap (b, n, m) { - var i = b[n]; - b[n] = b[m]; - b[m] = i; -} - -Buffer.prototype.swap16 = function swap16 () { - var len = this.length; - if (len % 2 !== 0) { - throw new RangeError('Buffer size must be a multiple of 16-bits') - } - for (var i = 0; i < len; i += 2) { - swap(this, i, i + 1); - } - return this -}; - -Buffer.prototype.swap32 = function swap32 () { - var len = this.length; - if (len % 4 !== 0) { - throw new RangeError('Buffer size must be a multiple of 32-bits') - } - for (var i = 0; i < len; i += 4) { - swap(this, i, i + 3); - swap(this, i + 1, i + 2); - } - return this -}; - -Buffer.prototype.swap64 = function swap64 () { - var len = this.length; - if (len % 8 !== 0) { - throw new RangeError('Buffer size must be a multiple of 64-bits') - } - for (var i = 0; i < len; i += 8) { - swap(this, i, i + 7); - swap(this, i + 1, i + 6); - swap(this, i + 2, i + 5); - swap(this, i + 3, i + 4); - } - return this -}; - -Buffer.prototype.toString = function toString () { - var length = this.length | 0; - if (length === 0) return '' - if (arguments.length === 0) return utf8Slice(this, 0, length) - return slowToString.apply(this, arguments) -}; - -Buffer.prototype.equals = function equals (b) { - if (!internalIsBuffer(b)) throw new TypeError('Argument must be a Buffer') - if (this === b) return true - return Buffer.compare(this, b) === 0 -}; - -Buffer.prototype.inspect = function inspect () { - var str = ''; - var max = INSPECT_MAX_BYTES; - if (this.length > 0) { - str = this.toString('hex', 0, max).match(/.{2}/g).join(' '); - if (this.length > max) str += ' ... '; - } - return '' -}; - -Buffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) { - if (!internalIsBuffer(target)) { - throw new TypeError('Argument must be a Buffer') - } - - if (start === undefined) { - start = 0; - } - if (end === undefined) { - end = target ? target.length : 0; - } - if (thisStart === undefined) { - thisStart = 0; - } - if (thisEnd === undefined) { - thisEnd = this.length; - } - - if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) { - throw new RangeError('out of range index') - } - - if (thisStart >= thisEnd && start >= end) { - return 0 - } - if (thisStart >= thisEnd) { - return -1 - } - if (start >= end) { - return 1 - } - - start >>>= 0; - end >>>= 0; - thisStart >>>= 0; - thisEnd >>>= 0; - - if (this === target) return 0 - - var x = thisEnd - thisStart; - var y = end - start; - var len = Math.min(x, y); - - var thisCopy = this.slice(thisStart, thisEnd); - var targetCopy = target.slice(start, end); - - for (var i = 0; i < len; ++i) { - if (thisCopy[i] !== targetCopy[i]) { - x = thisCopy[i]; - y = targetCopy[i]; - break - } - } - - if (x < y) return -1 - if (y < x) return 1 - return 0 -}; - -// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`, -// OR the last index of `val` in `buffer` at offset <= `byteOffset`. -// -// Arguments: -// - buffer - a Buffer to search -// - val - a string, Buffer, or number -// - byteOffset - an index into `buffer`; will be clamped to an int32 -// - encoding - an optional encoding, relevant is val is a string -// - dir - true for indexOf, false for lastIndexOf -function bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) { - // Empty buffer means no match - if (buffer.length === 0) return -1 - - // Normalize byteOffset - if (typeof byteOffset === 'string') { - encoding = byteOffset; - byteOffset = 0; - } else if (byteOffset > 0x7fffffff) { - byteOffset = 0x7fffffff; - } else if (byteOffset < -0x80000000) { - byteOffset = -0x80000000; - } - byteOffset = +byteOffset; // Coerce to Number. - if (isNaN(byteOffset)) { - // byteOffset: it it's undefined, null, NaN, "foo", etc, search whole buffer - byteOffset = dir ? 0 : (buffer.length - 1); - } - - // Normalize byteOffset: negative offsets start from the end of the buffer - if (byteOffset < 0) byteOffset = buffer.length + byteOffset; - if (byteOffset >= buffer.length) { - if (dir) return -1 - else byteOffset = buffer.length - 1; - } else if (byteOffset < 0) { - if (dir) byteOffset = 0; - else return -1 - } - - // Normalize val - if (typeof val === 'string') { - val = Buffer.from(val, encoding); - } - - // Finally, search either indexOf (if dir is true) or lastIndexOf - if (internalIsBuffer(val)) { - // Special case: looking for empty string/buffer always fails - if (val.length === 0) { - return -1 - } - return arrayIndexOf(buffer, val, byteOffset, encoding, dir) - } else if (typeof val === 'number') { - val = val & 0xFF; // Search for a byte value [0-255] - if (Buffer.TYPED_ARRAY_SUPPORT && - typeof Uint8Array.prototype.indexOf === 'function') { - if (dir) { - return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset) - } else { - return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset) - } - } - return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir) - } - - throw new TypeError('val must be string, number or Buffer') -} - -function arrayIndexOf (arr, val, byteOffset, encoding, dir) { - var indexSize = 1; - var arrLength = arr.length; - var valLength = val.length; - - if (encoding !== undefined) { - encoding = String(encoding).toLowerCase(); - if (encoding === 'ucs2' || encoding === 'ucs-2' || - encoding === 'utf16le' || encoding === 'utf-16le') { - if (arr.length < 2 || val.length < 2) { - return -1 - } - indexSize = 2; - arrLength /= 2; - valLength /= 2; - byteOffset /= 2; - } - } - - function read (buf, i) { - if (indexSize === 1) { - return buf[i] - } else { - return buf.readUInt16BE(i * indexSize) - } - } - - var i; - if (dir) { - var foundIndex = -1; - for (i = byteOffset; i < arrLength; i++) { - if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) { - if (foundIndex === -1) foundIndex = i; - if (i - foundIndex + 1 === valLength) return foundIndex * indexSize - } else { - if (foundIndex !== -1) i -= i - foundIndex; - foundIndex = -1; - } - } - } else { - if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength; - for (i = byteOffset; i >= 0; i--) { - var found = true; - for (var j = 0; j < valLength; j++) { - if (read(arr, i + j) !== read(val, j)) { - found = false; - break - } - } - if (found) return i - } - } - - return -1 -} - -Buffer.prototype.includes = function includes (val, byteOffset, encoding) { - return this.indexOf(val, byteOffset, encoding) !== -1 -}; - -Buffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) { - return bidirectionalIndexOf(this, val, byteOffset, encoding, true) -}; - -Buffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) { - return bidirectionalIndexOf(this, val, byteOffset, encoding, false) -}; - -function hexWrite (buf, string, offset, length) { - offset = Number(offset) || 0; - var remaining = buf.length - offset; - if (!length) { - length = remaining; - } else { - length = Number(length); - if (length > remaining) { - length = remaining; - } - } - - // must be an even number of digits - var strLen = string.length; - if (strLen % 2 !== 0) throw new TypeError('Invalid hex string') - - if (length > strLen / 2) { - length = strLen / 2; - } - for (var i = 0; i < length; ++i) { - var parsed = parseInt(string.substr(i * 2, 2), 16); - if (isNaN(parsed)) return i - buf[offset + i] = parsed; - } - return i -} - -function utf8Write (buf, string, offset, length) { - return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) -} - -function asciiWrite (buf, string, offset, length) { - return blitBuffer(asciiToBytes(string), buf, offset, length) -} - -function latin1Write (buf, string, offset, length) { - return asciiWrite(buf, string, offset, length) -} - -function base64Write (buf, string, offset, length) { - return blitBuffer(base64ToBytes(string), buf, offset, length) -} - -function ucs2Write (buf, string, offset, length) { - return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) -} - -Buffer.prototype.write = function write (string, offset, length, encoding) { - // Buffer#write(string) - if (offset === undefined) { - encoding = 'utf8'; - length = this.length; - offset = 0; - // Buffer#write(string, encoding) - } else if (length === undefined && typeof offset === 'string') { - encoding = offset; - length = this.length; - offset = 0; - // Buffer#write(string, offset[, length][, encoding]) - } else if (isFinite(offset)) { - offset = offset | 0; - if (isFinite(length)) { - length = length | 0; - if (encoding === undefined) encoding = 'utf8'; - } else { - encoding = length; - length = undefined; - } - // legacy write(string, encoding, offset, length) - remove in v0.13 - } else { - throw new Error( - 'Buffer.write(string, encoding, offset[, length]) is no longer supported' - ) - } - - var remaining = this.length - offset; - if (length === undefined || length > remaining) length = remaining; - - if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { - throw new RangeError('Attempt to write outside buffer bounds') - } - - if (!encoding) encoding = 'utf8'; - - var loweredCase = false; - for (;;) { - switch (encoding) { - case 'hex': - return hexWrite(this, string, offset, length) - - case 'utf8': - case 'utf-8': - return utf8Write(this, string, offset, length) - - case 'ascii': - return asciiWrite(this, string, offset, length) - - case 'latin1': - case 'binary': - return latin1Write(this, string, offset, length) - - case 'base64': - // Warning: maxLength not taken into account in base64Write - return base64Write(this, string, offset, length) - - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return ucs2Write(this, string, offset, length) - - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = ('' + encoding).toLowerCase(); - loweredCase = true; - } - } -}; - -Buffer.prototype.toJSON = function toJSON () { - return { - type: 'Buffer', - data: Array.prototype.slice.call(this._arr || this, 0) - } -}; - -function base64Slice (buf, start, end) { - if (start === 0 && end === buf.length) { - return fromByteArray(buf) - } else { - return fromByteArray(buf.slice(start, end)) - } -} - -function utf8Slice (buf, start, end) { - end = Math.min(buf.length, end); - var res = []; - - var i = start; - while (i < end) { - var firstByte = buf[i]; - var codePoint = null; - var bytesPerSequence = (firstByte > 0xEF) ? 4 - : (firstByte > 0xDF) ? 3 - : (firstByte > 0xBF) ? 2 - : 1; - - if (i + bytesPerSequence <= end) { - var secondByte, thirdByte, fourthByte, tempCodePoint; - - switch (bytesPerSequence) { - case 1: - if (firstByte < 0x80) { - codePoint = firstByte; - } - break - case 2: - secondByte = buf[i + 1]; - if ((secondByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F); - if (tempCodePoint > 0x7F) { - codePoint = tempCodePoint; - } - } - break - case 3: - secondByte = buf[i + 1]; - thirdByte = buf[i + 2]; - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F); - if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { - codePoint = tempCodePoint; - } - } - break - case 4: - secondByte = buf[i + 1]; - thirdByte = buf[i + 2]; - fourthByte = buf[i + 3]; - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F); - if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { - codePoint = tempCodePoint; - } - } - } - } - - if (codePoint === null) { - // we did not generate a valid codePoint so insert a - // replacement char (U+FFFD) and advance only 1 byte - codePoint = 0xFFFD; - bytesPerSequence = 1; - } else if (codePoint > 0xFFFF) { - // encode to utf16 (surrogate pair dance) - codePoint -= 0x10000; - res.push(codePoint >>> 10 & 0x3FF | 0xD800); - codePoint = 0xDC00 | codePoint & 0x3FF; - } - - res.push(codePoint); - i += bytesPerSequence; - } - - return decodeCodePointsArray(res) -} - -// Based on http://stackoverflow.com/a/22747272/680742, the browser with -// the lowest limit is Chrome, with 0x10000 args. -// We go 1 magnitude less, for safety -var MAX_ARGUMENTS_LENGTH = 0x1000; - -function decodeCodePointsArray (codePoints) { - var len = codePoints.length; - if (len <= MAX_ARGUMENTS_LENGTH) { - return String.fromCharCode.apply(String, codePoints) // avoid extra slice() - } - - // Decode in chunks to avoid "call stack size exceeded". - var res = ''; - var i = 0; - while (i < len) { - res += String.fromCharCode.apply( - String, - codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) - ); - } - return res -} - -function asciiSlice (buf, start, end) { - var ret = ''; - end = Math.min(buf.length, end); - - for (var i = start; i < end; ++i) { - ret += String.fromCharCode(buf[i] & 0x7F); - } - return ret -} - -function latin1Slice (buf, start, end) { - var ret = ''; - end = Math.min(buf.length, end); - - for (var i = start; i < end; ++i) { - ret += String.fromCharCode(buf[i]); - } - return ret -} - -function hexSlice (buf, start, end) { - var len = buf.length; - - if (!start || start < 0) start = 0; - if (!end || end < 0 || end > len) end = len; - - var out = ''; - for (var i = start; i < end; ++i) { - out += toHex(buf[i]); - } - return out -} - -function utf16leSlice (buf, start, end) { - var bytes = buf.slice(start, end); - var res = ''; - for (var i = 0; i < bytes.length; i += 2) { - res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256); - } - return res -} - -Buffer.prototype.slice = function slice (start, end) { - var len = this.length; - start = ~~start; - end = end === undefined ? len : ~~end; - - if (start < 0) { - start += len; - if (start < 0) start = 0; - } else if (start > len) { - start = len; - } - - if (end < 0) { - end += len; - if (end < 0) end = 0; - } else if (end > len) { - end = len; - } - - if (end < start) end = start; - - var newBuf; - if (Buffer.TYPED_ARRAY_SUPPORT) { - newBuf = this.subarray(start, end); - newBuf.__proto__ = Buffer.prototype; - } else { - var sliceLen = end - start; - newBuf = new Buffer(sliceLen, undefined); - for (var i = 0; i < sliceLen; ++i) { - newBuf[i] = this[i + start]; - } - } - - return newBuf -}; - -/* - * Need to make sure that buffer isn't trying to write out of bounds. - */ -function checkOffset (offset, ext, length) { - if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') - if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') -} - -Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var val = this[offset]; - var mul = 1; - var i = 0; - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul; - } - - return val -}; - -Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - checkOffset(offset, byteLength, this.length); - } - - var val = this[offset + --byteLength]; - var mul = 1; - while (byteLength > 0 && (mul *= 0x100)) { - val += this[offset + --byteLength] * mul; - } - - return val -}; - -Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length); - return this[offset] -}; - -Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - return this[offset] | (this[offset + 1] << 8) -}; - -Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - return (this[offset] << 8) | this[offset + 1] -}; - -Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return ((this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16)) + - (this[offset + 3] * 0x1000000) -}; - -Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset] * 0x1000000) + - ((this[offset + 1] << 16) | - (this[offset + 2] << 8) | - this[offset + 3]) -}; - -Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var val = this[offset]; - var mul = 1; - var i = 0; - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul; - } - mul *= 0x80; - - if (val >= mul) val -= Math.pow(2, 8 * byteLength); - - return val -}; - -Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var i = byteLength; - var mul = 1; - var val = this[offset + --i]; - while (i > 0 && (mul *= 0x100)) { - val += this[offset + --i] * mul; - } - mul *= 0x80; - - if (val >= mul) val -= Math.pow(2, 8 * byteLength); - - return val -}; - -Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length); - if (!(this[offset] & 0x80)) return (this[offset]) - return ((0xff - this[offset] + 1) * -1) -}; - -Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - var val = this[offset] | (this[offset + 1] << 8); - return (val & 0x8000) ? val | 0xFFFF0000 : val -}; - -Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - var val = this[offset + 1] | (this[offset] << 8); - return (val & 0x8000) ? val | 0xFFFF0000 : val -}; - -Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16) | - (this[offset + 3] << 24) -}; - -Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset] << 24) | - (this[offset + 1] << 16) | - (this[offset + 2] << 8) | - (this[offset + 3]) -}; - -Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - return read(this, offset, true, 23, 4) -}; - -Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - return read(this, offset, false, 23, 4) -}; - -Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length); - return read(this, offset, true, 52, 8) -}; - -Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length); - return read(this, offset, false, 52, 8) -}; - -function checkInt (buf, value, offset, ext, max, min) { - if (!internalIsBuffer(buf)) throw new TypeError('"buffer" argument must be a Buffer instance') - if (value > max || value < min) throw new RangeError('"value" argument is out of bounds') - if (offset + ext > buf.length) throw new RangeError('Index out of range') -} - -Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - var maxBytes = Math.pow(2, 8 * byteLength) - 1; - checkInt(this, value, offset, byteLength, maxBytes, 0); - } - - var mul = 1; - var i = 0; - this[offset] = value & 0xFF; - while (++i < byteLength && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - var maxBytes = Math.pow(2, 8 * byteLength) - 1; - checkInt(this, value, offset, byteLength, maxBytes, 0); - } - - var i = byteLength - 1; - var mul = 1; - this[offset + i] = value & 0xFF; - while (--i >= 0 && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0); - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value); - this[offset] = (value & 0xff); - return offset + 1 -}; - -function objectWriteUInt16 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffff + value + 1; - for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) { - buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>> - (littleEndian ? i : 1 - i) * 8; - } -} - -Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - } else { - objectWriteUInt16(this, value, offset, true); - } - return offset + 2 -}; - -Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8); - this[offset + 1] = (value & 0xff); - } else { - objectWriteUInt16(this, value, offset, false); - } - return offset + 2 -}; - -function objectWriteUInt32 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffffffff + value + 1; - for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) { - buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff; - } -} - -Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset + 3] = (value >>> 24); - this[offset + 2] = (value >>> 16); - this[offset + 1] = (value >>> 8); - this[offset] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, true); - } - return offset + 4 -}; - -Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24); - this[offset + 1] = (value >>> 16); - this[offset + 2] = (value >>> 8); - this[offset + 3] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, false); - } - return offset + 4 -}; - -Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1); - - checkInt(this, value, offset, byteLength, limit - 1, -limit); - } - - var i = 0; - var mul = 1; - var sub = 0; - this[offset] = value & 0xFF; - while (++i < byteLength && (mul *= 0x100)) { - if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) { - sub = 1; - } - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1); - - checkInt(this, value, offset, byteLength, limit - 1, -limit); - } - - var i = byteLength - 1; - var mul = 1; - var sub = 0; - this[offset + i] = value & 0xFF; - while (--i >= 0 && (mul *= 0x100)) { - if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) { - sub = 1; - } - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF; - } - - return offset + byteLength -}; - -Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80); - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value); - if (value < 0) value = 0xff + value + 1; - this[offset] = (value & 0xff); - return offset + 1 -}; - -Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - } else { - objectWriteUInt16(this, value, offset, true); - } - return offset + 2 -}; - -Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8); - this[offset + 1] = (value & 0xff); - } else { - objectWriteUInt16(this, value, offset, false); - } - return offset + 2 -}; - -Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - this[offset + 2] = (value >>> 16); - this[offset + 3] = (value >>> 24); - } else { - objectWriteUInt32(this, value, offset, true); - } - return offset + 4 -}; - -Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000); - if (value < 0) value = 0xffffffff + value + 1; - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24); - this[offset + 1] = (value >>> 16); - this[offset + 2] = (value >>> 8); - this[offset + 3] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, false); - } - return offset + 4 -}; - -function checkIEEE754 (buf, value, offset, ext, max, min) { - if (offset + ext > buf.length) throw new RangeError('Index out of range') - if (offset < 0) throw new RangeError('Index out of range') -} - -function writeFloat (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 4); - } - write(buf, value, offset, littleEndian, 23, 4); - return offset + 4 -} - -Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { - return writeFloat(this, value, offset, true, noAssert) -}; - -Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { - return writeFloat(this, value, offset, false, noAssert) -}; - -function writeDouble (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 8); - } - write(buf, value, offset, littleEndian, 52, 8); - return offset + 8 -} - -Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { - return writeDouble(this, value, offset, true, noAssert) -}; - -Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { - return writeDouble(this, value, offset, false, noAssert) -}; - -// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) -Buffer.prototype.copy = function copy (target, targetStart, start, end) { - if (!start) start = 0; - if (!end && end !== 0) end = this.length; - if (targetStart >= target.length) targetStart = target.length; - if (!targetStart) targetStart = 0; - if (end > 0 && end < start) end = start; - - // Copy 0 bytes; we're done - if (end === start) return 0 - if (target.length === 0 || this.length === 0) return 0 - - // Fatal error conditions - if (targetStart < 0) { - throw new RangeError('targetStart out of bounds') - } - if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds') - if (end < 0) throw new RangeError('sourceEnd out of bounds') - - // Are we oob? - if (end > this.length) end = this.length; - if (target.length - targetStart < end - start) { - end = target.length - targetStart + start; - } - - var len = end - start; - var i; - - if (this === target && start < targetStart && targetStart < end) { - // descending copy from end - for (i = len - 1; i >= 0; --i) { - target[i + targetStart] = this[i + start]; - } - } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) { - // ascending copy from start - for (i = 0; i < len; ++i) { - target[i + targetStart] = this[i + start]; - } - } else { - Uint8Array.prototype.set.call( - target, - this.subarray(start, start + len), - targetStart - ); - } - - return len -}; - -// Usage: -// buffer.fill(number[, offset[, end]]) -// buffer.fill(buffer[, offset[, end]]) -// buffer.fill(string[, offset[, end]][, encoding]) -Buffer.prototype.fill = function fill (val, start, end, encoding) { - // Handle string cases: - if (typeof val === 'string') { - if (typeof start === 'string') { - encoding = start; - start = 0; - end = this.length; - } else if (typeof end === 'string') { - encoding = end; - end = this.length; - } - if (val.length === 1) { - var code = val.charCodeAt(0); - if (code < 256) { - val = code; - } - } - if (encoding !== undefined && typeof encoding !== 'string') { - throw new TypeError('encoding must be a string') - } - if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) { - throw new TypeError('Unknown encoding: ' + encoding) - } - } else if (typeof val === 'number') { - val = val & 255; - } - - // Invalid ranges are not set to a default, so can range check early. - if (start < 0 || this.length < start || this.length < end) { - throw new RangeError('Out of range index') - } - - if (end <= start) { - return this - } - - start = start >>> 0; - end = end === undefined ? this.length : end >>> 0; - - if (!val) val = 0; - - var i; - if (typeof val === 'number') { - for (i = start; i < end; ++i) { - this[i] = val; - } - } else { - var bytes = internalIsBuffer(val) - ? val - : utf8ToBytes(new Buffer(val, encoding).toString()); - var len = bytes.length; - for (i = 0; i < end - start; ++i) { - this[i + start] = bytes[i % len]; - } - } - - return this -}; - -// HELPER FUNCTIONS -// ================ - -var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g; - -function base64clean (str) { - // Node strips out invalid characters like \n and \t from the string, base64-js does not - str = stringtrim(str).replace(INVALID_BASE64_RE, ''); - // Node converts strings with length < 2 to '' - if (str.length < 2) return '' - // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not - while (str.length % 4 !== 0) { - str = str + '='; - } - return str -} - -function stringtrim (str) { - if (str.trim) return str.trim() - return str.replace(/^\s+|\s+$/g, '') -} - -function toHex (n) { - if (n < 16) return '0' + n.toString(16) - return n.toString(16) -} - -function utf8ToBytes (string, units) { - units = units || Infinity; - var codePoint; - var length = string.length; - var leadSurrogate = null; - var bytes = []; - - for (var i = 0; i < length; ++i) { - codePoint = string.charCodeAt(i); - - // is surrogate component - if (codePoint > 0xD7FF && codePoint < 0xE000) { - // last char was a lead - if (!leadSurrogate) { - // no lead yet - if (codePoint > 0xDBFF) { - // unexpected trail - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - continue - } else if (i + 1 === length) { - // unpaired lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - continue - } - - // valid lead - leadSurrogate = codePoint; - - continue - } - - // 2 leads in a row - if (codePoint < 0xDC00) { - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - leadSurrogate = codePoint; - continue - } - - // valid surrogate pair - codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000; - } else if (leadSurrogate) { - // valid bmp char, but last char was a lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - } - - leadSurrogate = null; - - // encode utf8 - if (codePoint < 0x80) { - if ((units -= 1) < 0) break - bytes.push(codePoint); - } else if (codePoint < 0x800) { - if ((units -= 2) < 0) break - bytes.push( - codePoint >> 0x6 | 0xC0, - codePoint & 0x3F | 0x80 - ); - } else if (codePoint < 0x10000) { - if ((units -= 3) < 0) break - bytes.push( - codePoint >> 0xC | 0xE0, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ); - } else if (codePoint < 0x110000) { - if ((units -= 4) < 0) break - bytes.push( - codePoint >> 0x12 | 0xF0, - codePoint >> 0xC & 0x3F | 0x80, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ); - } else { - throw new Error('Invalid code point') - } - } - - return bytes -} - -function asciiToBytes (str) { - var byteArray = []; - for (var i = 0; i < str.length; ++i) { - // Node's code seems to be doing this and not & 0x7F.. - byteArray.push(str.charCodeAt(i) & 0xFF); - } - return byteArray -} - -function utf16leToBytes (str, units) { - var c, hi, lo; - var byteArray = []; - for (var i = 0; i < str.length; ++i) { - if ((units -= 2) < 0) break - - c = str.charCodeAt(i); - hi = c >> 8; - lo = c % 256; - byteArray.push(lo); - byteArray.push(hi); - } - - return byteArray -} - - -function base64ToBytes (str) { - return toByteArray(base64clean(str)) -} - -function blitBuffer (src, dst, offset, length) { - for (var i = 0; i < length; ++i) { - if ((i + offset >= dst.length) || (i >= src.length)) break - dst[i + offset] = src[i]; - } - return i -} - -function isnan (val) { - return val !== val // eslint-disable-line no-self-compare -} - - -// the following is from is-buffer, also by Feross Aboukhadijeh and with same lisence -// The _isBuffer check is for Safari 5-7 support, because it's missing -// Object.prototype.constructor. Remove this eventually -function isBuffer(obj) { - return obj != null && (!!obj._isBuffer || isFastBuffer(obj) || isSlowBuffer(obj)) -} - -function isFastBuffer (obj) { - return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj) -} - -// For Node v0.10 support. Remove this eventually. -function isSlowBuffer (obj) { - return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isFastBuffer(obj.slice(0, 0)) -} - -// Copyright Joyent, Inc. and other Node contributors. -var isBufferEncoding = Buffer.isEncoding - || function(encoding) { - switch (encoding && encoding.toLowerCase()) { - case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true; - default: return false; - } - }; - - -function assertEncoding(encoding) { - if (encoding && !isBufferEncoding(encoding)) { - throw new Error('Unknown encoding: ' + encoding); - } -} - -// StringDecoder provides an interface for efficiently splitting a series of -// buffers into a series of JS strings without breaking apart multi-byte -// characters. CESU-8 is handled as part of the UTF-8 encoding. -// -// @TODO Handling all encodings inside a single object makes it very difficult -// to reason about this code, so it should be split up in the future. -// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code -// points as used by CESU-8. -function StringDecoder(encoding) { - this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, ''); - assertEncoding(encoding); - switch (this.encoding) { - case 'utf8': - // CESU-8 represents each of Surrogate Pair by 3-bytes - this.surrogateSize = 3; - break; - case 'ucs2': - case 'utf16le': - // UTF-16 represents each of Surrogate Pair by 2-bytes - this.surrogateSize = 2; - this.detectIncompleteChar = utf16DetectIncompleteChar; - break; - case 'base64': - // Base-64 stores 3 bytes in 4 chars, and pads the remainder. - this.surrogateSize = 3; - this.detectIncompleteChar = base64DetectIncompleteChar; - break; - default: - this.write = passThroughWrite; - return; - } - - // Enough space to store all bytes of a single character. UTF-8 needs 4 - // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate). - this.charBuffer = new Buffer(6); - // Number of bytes received for the current incomplete multi-byte character. - this.charReceived = 0; - // Number of bytes expected for the current incomplete multi-byte character. - this.charLength = 0; -} - -// write decodes the given buffer and returns it as JS string that is -// guaranteed to not contain any partial multi-byte characters. Any partial -// character found at the end of the buffer is buffered up, and will be -// returned when calling write again with the remaining bytes. -// -// Note: Converting a Buffer containing an orphan surrogate to a String -// currently works, but converting a String to a Buffer (via `new Buffer`, or -// Buffer#write) will replace incomplete surrogates with the unicode -// replacement character. See https://codereview.chromium.org/121173009/ . -StringDecoder.prototype.write = function(buffer) { - var charStr = ''; - // if our last write ended with an incomplete multibyte character - while (this.charLength) { - // determine how many remaining bytes this buffer has to offer for this char - var available = (buffer.length >= this.charLength - this.charReceived) ? - this.charLength - this.charReceived : - buffer.length; - - // add the new bytes to the char buffer - buffer.copy(this.charBuffer, this.charReceived, 0, available); - this.charReceived += available; - - if (this.charReceived < this.charLength) { - // still not enough chars in this buffer? wait for more ... - return ''; - } - - // remove bytes belonging to the current character from the buffer - buffer = buffer.slice(available, buffer.length); - - // get the character that was split - charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding); - - // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character - var charCode = charStr.charCodeAt(charStr.length - 1); - if (charCode >= 0xD800 && charCode <= 0xDBFF) { - this.charLength += this.surrogateSize; - charStr = ''; - continue; - } - this.charReceived = this.charLength = 0; - - // if there are no more bytes in this buffer, just emit our char - if (buffer.length === 0) { - return charStr; - } - break; - } - - // determine and set charLength / charReceived - this.detectIncompleteChar(buffer); - - var end = buffer.length; - if (this.charLength) { - // buffer the incomplete character bytes we got - buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end); - end -= this.charReceived; - } - - charStr += buffer.toString(this.encoding, 0, end); - - var end = charStr.length - 1; - var charCode = charStr.charCodeAt(end); - // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character - if (charCode >= 0xD800 && charCode <= 0xDBFF) { - var size = this.surrogateSize; - this.charLength += size; - this.charReceived += size; - this.charBuffer.copy(this.charBuffer, size, 0, size); - buffer.copy(this.charBuffer, 0, 0, size); - return charStr.substring(0, end); - } - - // or just emit the charStr - return charStr; -}; - -// detectIncompleteChar determines if there is an incomplete UTF-8 character at -// the end of the given buffer. If so, it sets this.charLength to the byte -// length that character, and sets this.charReceived to the number of bytes -// that are available for this character. -StringDecoder.prototype.detectIncompleteChar = function(buffer) { - // determine how many bytes we have to check at the end of this buffer - var i = (buffer.length >= 3) ? 3 : buffer.length; - - // Figure out if one of the last i bytes of our buffer announces an - // incomplete char. - for (; i > 0; i--) { - var c = buffer[buffer.length - i]; - - // See http://en.wikipedia.org/wiki/UTF-8#Description - - // 110XXXXX - if (i == 1 && c >> 5 == 0x06) { - this.charLength = 2; - break; - } - - // 1110XXXX - if (i <= 2 && c >> 4 == 0x0E) { - this.charLength = 3; - break; - } - - // 11110XXX - if (i <= 3 && c >> 3 == 0x1E) { - this.charLength = 4; - break; - } - } - this.charReceived = i; -}; - -StringDecoder.prototype.end = function(buffer) { - var res = ''; - if (buffer && buffer.length) - res = this.write(buffer); - - if (this.charReceived) { - var cr = this.charReceived; - var buf = this.charBuffer; - var enc = this.encoding; - res += buf.slice(0, cr).toString(enc); - } - - return res; -}; - -function passThroughWrite(buffer) { - return buffer.toString(this.encoding); -} - -function utf16DetectIncompleteChar(buffer) { - this.charReceived = buffer.length % 2; - this.charLength = this.charReceived ? 2 : 0; -} - -function base64DetectIncompleteChar(buffer) { - this.charReceived = buffer.length % 3; - this.charLength = this.charReceived ? 3 : 0; -} - -const BUFFER_MAX_BYTES = 524288; // 0.5Mb - -const CONTINUE_READING_RECORDS = "CONTINUE_READING"; -const READ_REMAINING_TEXT = "READ_REMAINING"; -const CANCEL_READ = "CANCEL"; - -const getIndexWriter = (hierarchy, indexNode, readableStream, writableStream, end) => { - const schema = generateSchema(hierarchy, indexNode); - - return ({ - read: read$1(readableStream, schema), - updateIndex: updateIndex(readableStream, writableStream, schema) - }); -}; - -const getIndexReader = (hierarchy, indexNode, readableStream) => - read$1( - readableStream, - generateSchema(hierarchy, indexNode) - ); - -const updateIndex = (readableStream, writableStream, schema) => async (itemsToWrite, keysToRemove) => { - const write = newOutputWriter(BUFFER_MAX_BYTES, writableStream); - const writtenItems = []; - await read$1(readableStream, schema)( - async indexedItem => { - const updated = find(i => indexedItem.key === i.key)(itemsToWrite); - const removed = find(k => indexedItem.key === k)(keysToRemove); - - if(isSomething(removed)) - return CONTINUE_READING_RECORDS; - - if(isSomething(updated)) { - const serializedItem = serializeItem(schema, updated); - await write(serializedItem); - writtenItems.push(updated); - } else { - await write( - serializeItem(schema, indexedItem) - ); - } - - return CONTINUE_READING_RECORDS; - - }, - async text => await write(text) - ); - - if(writtenItems.length !== itemsToWrite.length) { - const toAdd = difference(itemsToWrite, writtenItems); - for(let added of toAdd) { - await write( - serializeItem(schema, added) - ); - } - } else if(writtenItems.length === 0) { - // potentially are no records - await write(""); - } - - await write(); - await writableStream.end(); -}; - -const read$1 = (readableStream, schema) => async (onGetItem, onGetText) => { - const readInput = newInputReader(readableStream); - let text = await readInput(); - let status = CONTINUE_READING_RECORDS; - while(text.length > 0) { - - if(status === READ_REMAINING_TEXT) { - await onGetText(text); - continue; - } - - if(status === CANCEL_READ) { - return; - } - - let rowText = ""; - let currentCharIndex=0; - for(let currentChar of text) { - rowText += currentChar; - if(currentChar === "\r") { - status = await onGetItem( - deserializeRow(schema, rowText) - ); - rowText = ""; - if(status === READ_REMAINING_TEXT) { - break; - } - } - currentCharIndex++; - } - - if(currentCharIndex < text.length -1) { - await onGetText(text.substring(currentCharIndex + 1)); - } - - text = await readInput(); - } - - await readableStream.destroy(); - -}; - -const newOutputWriter = (flushBoundary, writableStream) => { - - let currentBuffer = null; - - return async (text) => { - - if(isString(text) && currentBuffer === null) - currentBuffer = Buffer$1.from(text, "utf8"); - else if(isString(text)) - currentBuffer = Buffer$1.concat([ - currentBuffer, - Buffer$1.from(text, "utf8") - ]); - - if(currentBuffer !== null && - (currentBuffer.length > flushBoundary - || !isString(text))) { - - await writableStream.write(currentBuffer); - currentBuffer = null; - } - } -}; - -const newInputReader = (readableStream) => { - - const decoder = new StringDecoder('utf8'); - let remainingBytes = []; - - return async () => { - - let nextBytesBuffer = await readableStream.read(BUFFER_MAX_BYTES); - const remainingBuffer = Buffer$1.from(remainingBytes); - - if(!nextBytesBuffer) nextBytesBuffer = Buffer$1.from([]); - - const moreToRead = nextBytesBuffer.length === BUFFER_MAX_BYTES; - - const buffer = Buffer$1.concat( - [remainingBuffer, nextBytesBuffer], - remainingBuffer.length + nextBytesBuffer.length); - - const text = decoder.write(buffer); - remainingBytes = decoder.end(buffer); - - if(!moreToRead && remainingBytes.length > 0) { - // if for any reason, we have remaining bytes at the end - // of the stream, just discard - dont see why this should - // ever happen, but if it does, it could cause a stack overflow - remainingBytes = []; - } - - return text; - }; -}; - -const deserializeRow = (schema, rowText) => { - let currentPropIndex = 0; - let currentCharIndex = 0; - let currentValueText = ""; - let isEscaped = false; - const item = {}; - - const setCurrentProp = () => { - const currentProp = schema[currentPropIndex]; - const type = getType(currentProp.type); - const value = currentValueText === "" - ? type.getDefaultValue() - : type.safeParseValue( - currentValueText); - item[currentProp.name] = value; - }; - - while(currentPropIndex < schema.length) { - - if(currentCharIndex < rowText.length) { - const currentChar = rowText[currentCharIndex]; - if(isEscaped) { - if(currentChar === "r") { - currentValueText += "\r"; - } else { - currentValueText += currentChar; - } - isEscaped = false; - } else { - if(currentChar === ",") { - setCurrentProp(); - currentValueText = ""; - currentPropIndex++; - } else if(currentChar === "\\") { - isEscaped = true; - } else { - currentValueText += currentChar; - } - } - currentCharIndex++; - } else { - currentValueText = ""; - setCurrentProp(); - currentPropIndex++; - } - } - - return item; -}; - -const serializeItem = (schema, item) => { - - let rowText = ""; - - for(let prop of schema) { - const type = getType(prop.type); - const value = has(prop.name)(item) - ? item[prop.name] - : type.getDefaultValue(); - - const valStr = type.stringify(value); - - for(let i = 0; i < valStr.length; i++) { - const currentChar = valStr[i]; - if(currentChar === "," - || currentChar === "\r" - || currentChar === "\\") { - rowText += "\\"; - } - - if(currentChar === "\r") { - rowText += "r"; - } else { - rowText += currentChar; - } - } - - rowText += ","; - } - - rowText += "\r"; - return rowText; -}; - -const readIndex$1 = async (hierarchy, datastore, index, indexedDataKey) => { - const records = []; - const doRead = iterateIndex( - async item => { - records.push(item); - return CONTINUE_READING_RECORDS; - }, - async () => records - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); -}; - -const searchIndex = async (hierarchy, datastore, index, indexedDataKey, searchPhrase) => { - const records = []; - const schema = generateSchema(hierarchy, index); - const doRead = iterateIndex( - async item => { - const idx = lunr(function () { - this.ref('key'); - for (const field of schema) { - this.field(field.name); - } - this.add(item); - }); - const searchResults = idx.search(searchPhrase); - if (searchResults.length === 1) { - item._searchResult = searchResults[0]; - records.push(item); - } - return CONTINUE_READING_RECORDS; - }, - async () => records - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); -}; - -const iterateIndex = (onGetItem, getFinalResult) => async (hierarchy, datastore, index, indexedDataKey) => { - try { - const readableStream = promiseReadableStream( - await datastore.readableFileStream(indexedDataKey) - ); - - const read = getIndexReader(hierarchy, index, readableStream); - await read(onGetItem); - return getFinalResult(); - } catch (e) { - if (await datastore.exists(indexedDataKey)) { - throw e; - } else { - await createIndexFile( - datastore, - indexedDataKey, - index, - ); - } - return []; - } -}; - -const getIndexDir = (hierarchy, indexKey) => { - - const parentKey = getParentKey(indexKey); - - if(parentKey === "") return indexKey; - if(parentKey === keySep) return indexKey; - - const recordInfo = getRecordInfo( - hierarchy, - parentKey); - - return recordInfo.child( - getLastPartInKey(indexKey)); -}; - -const listItems = app => async (indexKey, options) => { - indexKey = safeKey(indexKey); - return apiWrapper( - app, - events.indexApi.listItems, - permission.readIndex.isAuthorized(indexKey), - { indexKey, options }, - _listItems, app, indexKey, options, - ); -}; - -const defaultOptions = { rangeStartParams: null, rangeEndParams: null, searchPhrase: null }; - -const _listItems = async (app, indexKey, options = defaultOptions) => { - const { searchPhrase, rangeStartParams, rangeEndParams } = $({}, [ - merge$1(options), - merge$1(defaultOptions), - ]); - - const getItems = async indexedDataKey => (isNonEmptyString(searchPhrase) - ? await searchIndex( - app.hierarchy, - app.datastore, - indexNode, - indexedDataKey, - searchPhrase, - ) - : await readIndex$1( - app.hierarchy, - app.datastore, - indexNode, - indexedDataKey, - )); - - indexKey = safeKey(indexKey); - const indexNode = getExactNodeForKey(app.hierarchy)(indexKey); - const indexDir = getIndexDir(app.hierarchy, indexKey); - - if (!isIndex(indexNode)) { throw new Error('supplied key is not an index'); } - - if (isShardedIndex(indexNode)) { - const shardKeys = await getShardKeysInRange( - app, indexNode, indexDir, rangeStartParams, rangeEndParams, - ); - const items = []; - for (const k of shardKeys) { - items.push(await getItems(k)); - } - return flatten(items); - } - return await getItems( - getUnshardedIndexDataKey(indexDir), - ); -}; - -const getContext = app => recordKey => { - recordKey = safeKey(recordKey); - return apiWrapperSync( - app, - events.recordApi.getContext, - permission.readRecord.isAuthorized(recordKey), - { recordKey }, - _getContext, app, recordKey, - ); -}; - -const _getContext = (app, recordKey) => { - recordKey = safeKey(recordKey); - const recordNode = getExactNodeForKey(app.hierarchy)(recordKey); - - const cachedReferenceIndexes = {}; - - const lazyLoadReferenceIndex = async (typeOptions) => { - if (!has(typeOptions.indexNodeKey)(cachedReferenceIndexes)) { - cachedReferenceIndexes[typeOptions.indexNodeKey] = { - typeOptions, - data: await readReferenceIndex( - app, recordKey, typeOptions, - ), - }; - } - - return cachedReferenceIndexes[typeOptions.indexNodeKey]; - }; - - const getTypeOptions = typeOptions_or_fieldName => (isString(typeOptions_or_fieldName) - ? findField(recordNode, typeOptions_or_fieldName) - .typeOptions - : typeOptions_or_fieldName); - - return { - referenceExists: async (typeOptions_or_fieldName, key) => { - const typeOptions = getTypeOptions(typeOptions_or_fieldName); - const { data } = await lazyLoadReferenceIndex(typeOptions); - return some(i => i.key === key)(data); - }, - referenceOptions: async (typeOptions_or_fieldName) => { - const typeOptions = getTypeOptions(typeOptions_or_fieldName); - const { data } = await lazyLoadReferenceIndex(typeOptions); - return data; - }, - recordNode, - }; -}; - -const readReferenceIndex = async (app, recordKey, typeOptions) => { - const indexNode = getNode(app.hierarchy, typeOptions.indexNodeKey); - const indexKey = isGlobalIndex(indexNode) - ? indexNode.nodeKey() - : getIndexKey_BasedOnDecendant( - recordKey, indexNode, - ); - - const items = await listItems(app)(indexKey); - return $(items, [ - map(i => ({ - key: i.key, - value: i[typeOptions.displayValue], - })), - ]); -}; - -const fieldParseError = (fieldName, value) => ({ - fields: [fieldName], - message: `Could not parse field ${fieldName}:${value}`, -}); - -const validateAllFieldParse = (record, recordNode) => $(recordNode.fields, [ - map(f => ({ name: f.name, parseResult: validateFieldParse(f, record) })), - reduce((errors, f) => { - if (f.parseResult.success) return errors; - errors.push( - fieldParseError(f.name, f.parseResult.value), - ); - return errors; - }, []), -]); - -const validateAllTypeConstraints = async (record, recordNode, context) => { - const errors = []; - for (const field of recordNode.fields) { - $(await validateTypeConstraints$1(field, record, context), [ - filter(isNonEmptyString), - map(m => ({ message: m, fields: [field.name] })), - each(e => errors.push(e)), - ]); - } - return errors; -}; - -const runRecordValidationRules = (record, recordNode) => { - const runValidationRule = (rule) => { - const isValid = compileExpression$1(rule.expressionWhenValid); - const expressionContext = { record, _ }; - return (isValid(expressionContext) - ? { valid: true } - : ({ - valid: false, - fields: rule.invalidFields, - message: rule.messageWhenInvalid, - })); - }; - - return $(recordNode.validationRules, [ - map(runValidationRule), - flatten, - filter(r => r.valid === false), - map(r => ({ fields: r.fields, message: r.message })), - ]); -}; - -const validate = app => async (record, context) => { - context = isNothing(context) - ? _getContext(app, record.key) - : context; - - const recordNode = getExactNodeForKey(app.hierarchy)(record.key); - const fieldParseFails = validateAllFieldParse(record, recordNode); - - // non parsing would cause further issues - exit here - if (!isEmpty(fieldParseFails)) { return ({ isValid: false, errors: fieldParseFails }); } - - const recordValidationRuleFails = runRecordValidationRules(record, recordNode); - const typeContraintFails = await validateAllTypeConstraints(record, recordNode, context); - - if (isEmpty(fieldParseFails) - && isEmpty(recordValidationRuleFails) - && isEmpty(typeContraintFails)) { - return ({ isValid: true, errors: [] }); - } - - return ({ - isValid: false, - errors: _.union(fieldParseFails, typeContraintFails, recordValidationRuleFails), - }); -}; - -const ensureCollectionIsInitialised = async (datastore, node, dir) => { - if (!await datastore.exists(dir)) { - await datastore.createFolder(dir); - await datastore.createFolder(joinKey(dir, node.nodeId)); - } -}; - -const initialiseRootCollections = async (datastore, hierarchy) => { - const rootCollectionRecord = allTrue( - n => isRoot(n.parent()), - isCollectionRecord, - ); - - const flathierarchy = getFlattenedHierarchy(hierarchy); - - const collectionRecords = $(flathierarchy, [ - filter(rootCollectionRecord), - ]); - - for (const col of collectionRecords) { - await ensureCollectionIsInitialised( - datastore, - col, - col.collectionPathRegx() - ); - } -}; - -const initialiseChildCollections = async (app, recordInfo) => { - const childCollectionRecords = $(recordInfo.recordNode, [ - n => n.children, - filter(isCollectionRecord), - ]); - - for (const child of childCollectionRecords) { - await ensureCollectionIsInitialised( - app.datastore, - child, - recordInfo.child(child.collectionName), - ); - } -}; - -const TRANSACTIONS_FOLDER = `${keySep}.transactions`; -const LOCK_FILENAME = 'lock'; -const LOCK_FILE_KEY = joinKey( - TRANSACTIONS_FOLDER, LOCK_FILENAME, -); -const idSep = '$'; - -const isOfType = typ => trans => trans.transactionType === typ; - -const CREATE_RECORD_TRANSACTION = 'create'; -const UPDATE_RECORD_TRANSACTION = 'update'; -const DELETE_RECORD_TRANSACTION = 'delete'; -const BUILD_INDEX_TRANSACTION = 'build'; - -const isUpdate = isOfType(UPDATE_RECORD_TRANSACTION); -const isDelete = isOfType(DELETE_RECORD_TRANSACTION); -const isCreate = isOfType(CREATE_RECORD_TRANSACTION); -const isBuildIndex = isOfType(BUILD_INDEX_TRANSACTION); - -const keyToFolderName = nodeKey => getHashCode(nodeKey); - -const getTransactionId = (recordId, transactionType, uniqueId) => - `${recordId}${idSep}${transactionType}${idSep}${uniqueId}`; - -const buildIndexFolder = '.BUILD-'; -const nodeKeyHashFromBuildFolder = folder => folder.replace(buildIndexFolder, ''); - -const isBuildIndexFolder = key => getLastPartInKey(key).startsWith(buildIndexFolder); - -const IndexNodeKeyFolder = indexNodeKey => joinKey( - TRANSACTIONS_FOLDER, - buildIndexFolder + keyToFolderName(indexNodeKey), -); - -const IndexNodeKeyBatchFolder = (indexNodeKey, count) => - joinKey(IndexNodeKeyFolder(indexNodeKey), Math.floor(count / BUILDINDEX_BATCH_COUNT).toString()); - -const BUILDINDEX_BATCH_COUNT = 1000; -const timeoutMilliseconds = 30 * 1000; // 30 secs -const maxLockRetries = 1; - -const transactionForCreateRecord = async (app, record) => await transaction( - app.datastore, CREATE_RECORD_TRANSACTION, - record.key, { record }, - getTransactionKey_Records, -); - -const transactionForUpdateRecord = async (app, oldRecord, newRecord) => await transaction( - app.datastore, UPDATE_RECORD_TRANSACTION, - newRecord.key, { oldRecord, record: newRecord }, - getTransactionKey_Records, -); - -const transactionForDeleteRecord = async (app, record) => await transaction( - app.datastore, DELETE_RECORD_TRANSACTION, - record.key, { record }, - getTransactionKey_Records, -); - -const transactionForBuildIndex = async (app, indexNodeKey, recordKey, count) => { - const transactionFolder = IndexNodeKeyBatchFolder(indexNodeKey, count); - if (count % BUILDINDEX_BATCH_COUNT === 0) { - await app.datastore.createFolder(transactionFolder); - } - - return await transaction( - app.datastore, BUILD_INDEX_TRANSACTION, - recordKey, { recordKey }, - id => joinKey(transactionFolder, id), - ); -}; - -const createBuildIndexFolder = async (datastore, indexNodeKey) => await datastore.createFolder( - IndexNodeKeyFolder(indexNodeKey), -); - -const getTransactionKey_Records = id => joinKey(TRANSACTIONS_FOLDER, id); - -const transaction = async (datastore, transactionType, recordKey, data, getTransactionKey) => { - const recordId = getLastPartInKey(recordKey); - const uniqueId = generate(); - const id = getTransactionId( - recordId, transactionType, uniqueId, - ); - - const key = getTransactionKey(id); - - const trans = { - transactionType, - recordKey, - ...data, - id, - }; - - await datastore.createJson( - key, trans, - ); - - return trans; -}; - -const initialiseIndex = async (datastore, dir, index) => { - const indexDir = joinKey(dir, index.name); - - await datastore.createFolder(indexDir); - - if (isShardedIndex(index)) { - await datastore.createFile( - getShardMapKey(indexDir), - '[]', - ); - } else { - await createIndexFile( - datastore, - getUnshardedIndexDataKey(indexDir), - index, - ); - } -}; - -const save = app => async (record, context) => apiWrapper( - app, - events.recordApi.save, - record.isNew - ? permission.createRecord.isAuthorized(record.key) - : permission.updateRecord.isAuthorized(record.key), { record }, - _save, app, record, context, false, -); - - -const _save = async (app, record, context, skipValidation = false) => { - const recordClone = cloneDeep(record); - if (!skipValidation) { - const validationResult = await validate(app)(recordClone, context); - if (!validationResult.isValid) { - await app.publish(events.recordApi.save.onInvalid, { record, validationResult }); - throw new BadRequestError(`Save : Record Invalid : ${ - JSON.stringify(validationResult.errors)}`); - } - } - - const recordInfo = getRecordInfo(app.hierarchy, record.key); - const { - recordNode, pathInfo, - recordJson, files, - } = recordInfo; - - if (recordClone.isNew) { - - if(!recordNode) - throw new Error("Cannot find node for " + record.key); - - const transaction = await transactionForCreateRecord( - app, recordClone, - ); - recordClone.transactionId = transaction.id; - await createRecordFolderPath(app.datastore, pathInfo); - await app.datastore.createFolder(files); - await app.datastore.createJson(recordJson, recordClone); - await initialiseReverseReferenceIndexes(app, recordInfo); - await initialiseAncestorIndexes(app, recordInfo); - await initialiseChildCollections(app, recordInfo); - await app.publish(events.recordApi.save.onRecordCreated, { - record: recordClone, - }); - } else { - const oldRecord = await _loadFromInfo(app, recordInfo); - const transaction = await transactionForUpdateRecord( - app, oldRecord, recordClone, - ); - recordClone.transactionId = transaction.id; - await app.datastore.updateJson( - recordJson, - recordClone, - ); - await app.publish(events.recordApi.save.onRecordUpdated, { - old: oldRecord, - new: recordClone, - }); - } - - await app.cleanupTransactions(); - - const returnedClone = cloneDeep(recordClone); - returnedClone.isNew = false; - return returnedClone; -}; - -const initialiseAncestorIndexes = async (app, recordInfo) => { - for (const index of recordInfo.recordNode.indexes) { - const indexKey = recordInfo.child(index.name); - if (!await app.datastore.exists(indexKey)) { - await initialiseIndex(app.datastore, recordInfo.dir, index); - } - } -}; - -const initialiseReverseReferenceIndexes = async (app, recordInfo) => { - - const indexNodes = $(fieldsThatReferenceThisRecord(app, recordInfo.recordNode), [ - map(f => $(f.typeOptions.reverseIndexNodeKeys, [ - map(n => getNode( - app.hierarchy, - n, - )), - ])), - flatten, - ]); - - for (const indexNode of indexNodes) { - await initialiseIndex( - app.datastore, recordInfo.dir, indexNode, - ); - } -}; - -const fieldsThatReferenceThisRecord = (app, recordNode) => $(app.hierarchy, [ - getFlattenedHierarchy, - filter(isRecord), - map(n => n.fields), - flatten, - filter(fieldReversesReferenceToNode(recordNode)), -]); - -const createRecordFolderPath = async (datastore, pathInfo) => { - - const recursiveCreateFolder = async (subdirs, dirsThatNeedCreated=undefined) => { - - // iterate backwards through directory hierachy - // until we get to a folder that exists, then create the rest - // e.g - // - some/folder/here - // - some/folder - // - some - const thisFolder = joinKey(pathInfo.base, ...subdirs); - - if(await datastore.exists(thisFolder)) { - - let creationFolder = thisFolder; - for(let nextDir of (dirsThatNeedCreated || []) ) { - creationFolder = joinKey(creationFolder, nextDir); - await datastore.createFolder(creationFolder); - } - - } else if(!dirsThatNeedCreated || dirsThatNeedCreated.length > 0) { - - dirsThatNeedCreated = !dirsThatNeedCreated - ? [] - :dirsThatNeedCreated; - - await recursiveCreateFolder( - take(subdirs.length - 1)(subdirs), - [...takeRight$1(1)(subdirs), ...dirsThatNeedCreated] - ); - } - }; - - await recursiveCreateFolder(pathInfo.subdirs); - - return joinKey(pathInfo.base, ...pathInfo.subdirs); - -}; - -const deleteCollection = (app, disableCleanup = false) => async key => apiWrapper( - app, - events.collectionApi.delete, - permission.manageCollection.isAuthorized, - { key }, - _deleteCollection, app, key, disableCleanup, -); - -/* - const recordNode = getCollectionNode(app.hierarchy, key); - -*/ - -const _deleteCollection = async (app, key, disableCleanup) => { - key = safeKey(key); - const collectionDir = getCollectionDir(app.hierarchy, key); - await deleteRecords(app, key); - await deleteCollectionFolder(app, collectionDir); - if (!disableCleanup) { await app.cleanupTransactions(); } -}; - -const deleteCollectionFolder = async (app, dir) => - await app.datastore.deleteFolder(dir); - -const deleteRecords = async (app, key) => { - - const iterate = await getAllIdsIterator(app)(key); - - let ids = await iterate(); - while (!ids.done) { - if (ids.result.collectionKey === key) { - for (const id of ids.result.ids) { - await _deleteRecord( - app, - joinKey(key, id), - true, - ); - } - } - - ids = await iterate(); - } -}; - -const deleteRecord$1 = (app, disableCleanup = false) => async key => { - key = safeKey(key); - return apiWrapper( - app, - events.recordApi.delete, - permission.deleteRecord.isAuthorized(key), - { key }, - _deleteRecord, app, key, disableCleanup, - ); -}; - -// called deleteRecord because delete is a keyword -const _deleteRecord = async (app, key, disableCleanup) => { - const recordInfo = getRecordInfo(app.hierarchy, key); - key = recordInfo.key; - const node = getExactNodeForKey(app.hierarchy)(key); - - const record = await _load(app, key); - await transactionForDeleteRecord(app, record); - - for (const collectionRecord of node.children) { - const collectionKey = joinKey( - key, collectionRecord.collectionName, - ); - await _deleteCollection(app, collectionKey, true); - } - - await app.datastore.deleteFolder(recordInfo.dir); - - if (!disableCleanup) { await app.cleanupTransactions(); } -}; - -const uploadFile = app => async (recordKey, readableStream, relativeFilePath) => apiWrapper( - app, - events.recordApi.uploadFile, - permission.updateRecord.isAuthorized(recordKey), - { recordKey, readableStream, relativeFilePath }, - _uploadFile, app, recordKey, readableStream, relativeFilePath, -); - -const _uploadFile = async (app, recordKey, readableStream, relativeFilePath) => { - if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); } - if (isNothing(relativeFilePath)) { throw new BadRequestError('file path not supplied'); } - if (!isLegalFilename(relativeFilePath)) { throw new BadRequestError('Illegal filename'); } - - const recordInfo = getRecordInfo(app.hierarchy, recordKey); - const record = await _loadFromInfo(app, recordInfo); - - const fullFilePath = safeGetFullFilePath( - recordInfo.dir, relativeFilePath, - ); - - const tempFilePath = `${fullFilePath}_${generate()}.temp`; - - const outputStream = await app.datastore.writableFileStream( - tempFilePath, - ); - - return new Promise((resolve,reject) => { - readableStream.pipe(outputStream); - outputStream.on('error', reject); - outputStream.on('finish', resolve); - }) - .then(() => app.datastore.getFileSize(tempFilePath)) - .then(size => { - const isExpectedFileSize = checkFileSizeAgainstFields( - app, record, relativeFilePath, size - ); - if (!isExpectedFileSize) { throw new BadRequestError(`Fields for ${relativeFilePath} do not have expected size: ${join(',')(incorrectFields)}`); } - - }) - .then(() => tryAwaitOrIgnore(app.datastore.deleteFile, fullFilePath)) - .then(() => app.datastore.renameFile(tempFilePath, fullFilePath)); - -}; - -const checkFileSizeAgainstFields = (app, record, relativeFilePath, expectedSize) => { - const recordNode = getExactNodeForKey(app.hierarchy)(record.key); - - const incorrectFileFields = $(recordNode.fields, [ - filter(f => f.type === 'file' - && record[f.name].relativePath === relativeFilePath - && record[f.name].size !== expectedSize), - map(f => f.name), - ]); - - const incorrectFileArrayFields = $(recordNode.fields, [ - filter(a => a.type === 'array' - && $(record[a.name], [ - some(f => record[f.name].relativePath === relativeFilePath - && record[f.name].size !== expectedSize), - ])), - map(f => f.name), - ]); - - const incorrectFields = [ - ...incorrectFileFields, - ...incorrectFileArrayFields, - ]; - - if (incorrectFields.length > 0) { - return false; - } - - return true; -}; - -const safeGetFullFilePath = (recordDir, relativeFilePath) => { - const naughtyUser = () => { throw new ForbiddenError('naughty naughty'); }; - - if (relativeFilePath.startsWith('..')) naughtyUser(); - - const pathParts = splitKey(relativeFilePath); - - if (includes('..')(pathParts)) naughtyUser(); - - const recordKeyParts = splitKey(recordDir); - - const fullPathParts = [ - ...recordKeyParts, - 'files', - ...filter(p => p !== '.')(pathParts), - ]; - - return joinKey(fullPathParts); -}; - -const downloadFile = app => async (recordKey, relativePath) => apiWrapper( - app, - events.recordApi.uploadFile, - permission.readRecord.isAuthorized(recordKey), - { recordKey, relativePath },//remove dupe key 'recordKey' from object - _downloadFile, app, recordKey, relativePath, -); - - -const _downloadFile = async (app, recordKey, relativePath) => { - if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); } - if (isNothing(relativePath)) { throw new BadRequestError('file path not supplied'); } - - const {dir} = getRecordInfo(app.hierarchy, recordKey); - return await app.datastore.readableFileStream( - safeGetFullFilePath( - dir, relativePath, - ), - ); -}; - -const customId = app => (nodeName, id) => { - const node = $(app.hierarchy, [ - getFlattenedHierarchy, - find(n => n.name === nodeName), - ]); - - if (!node) throw new NotFoundError(`Cannot find node ${nodeName}`); - - return `${node.nodeId}-${id}`; -}; - -const setCustomId = app => (record, id) => { - record.id = customId(app)(record.type, id); - - const keyParts = splitKey(record.key); - - record.key = $(keyParts, [ - take(keyParts.length - 1), - union([record.id]), - joinKey, - ]); - - return record; -}; - -const api = app => ({ - getNew: getNew(app), - getNewChild: getNewChild(app), - save: save(app), - load: load(app), - delete: deleteRecord$1(app, false), - validate: validate(app), - getContext: getContext(app), - uploadFile: uploadFile(app), - downloadFile: downloadFile(app), - customId: customId(app), - setCustomId: setCustomId(app), -}); - - -const getRecordApi = app => api(app); - -const getAllowedRecordTypes = app => key => apiWrapperSync( - app, - events.collectionApi.getAllowedRecordTypes, - alwaysAuthorized, - { key }, - _getAllowedRecordTypes, app, key, -); - -const _getAllowedRecordTypes = (app, key) => { - key = safeKey(key); - const node = getNodeForCollectionPath(app.hierarchy)(key); - return isNothing(node) ? [] : [node.name]; -}; - -const getCollectionApi = app => ({ - getAllowedRecordTypes: getAllowedRecordTypes(app), - getAllIdsIterator: getAllIdsIterator(app), - delete: deleteCollection(app), -}); - -/** rebuilds an index - * @param {object} app - the application container - * @param {string} indexNodeKey - node key of the index, which the index belongs to - */ -const buildIndex = app => async indexNodeKey => apiWrapper( - app, - events.indexApi.buildIndex, - permission.manageIndex.isAuthorized, - { indexNodeKey }, - _buildIndex, app, indexNodeKey, -); - -const _buildIndex = async (app, indexNodeKey) => { - const indexNode = getNode(app.hierarchy, indexNodeKey); - - await createBuildIndexFolder(app.datastore, indexNodeKey); - - if (!isIndex(indexNode)) { throw new BadRequestError('BuildIndex: must supply an indexnode'); } - - if (indexNode.indexType === 'reference') { - await buildReverseReferenceIndex( - app, indexNode, - ); - } else { - await buildHeirarchalIndex( - app, indexNode, - ); - } - - await app.cleanupTransactions(); -}; - -const buildReverseReferenceIndex = async (app, indexNode) => { - // Iterate through all referencING records, - // and update referenced index for each record - let recordCount = 0; - const referencingNodes = $(app.hierarchy, [ - getFlattenedHierarchy, - filter(n => isRecord(n) - && some(fieldReversesReferenceToIndex(indexNode))(n.fields)), - ]); - - const createTransactionsForReferencingNode = async (referencingNode) => { - const iterateReferencingNodes = await getAllIdsIterator(app)(referencingNode.collectionNodeKey()); - - let referencingIdIterator = await iterateReferencingNodes(); - while (!referencingIdIterator.done) { - const { result } = referencingIdIterator; - for (const id of result.ids) { - const recordKey = joinKey(result.collectionKey, id); - await transactionForBuildIndex(app, indexNode.nodeKey(), recordKey, recordCount); - recordCount++; - } - referencingIdIterator = await iterateReferencingNodes(); - } - }; - - for (const referencingNode of referencingNodes) { - await createTransactionsForReferencingNode(referencingNode); - } -}; - -/* -const getAllowedParentCollectionNodes = (hierarchy, indexNode) => $(getAllowedRecordNodesForIndex(hierarchy, indexNode), [ - map(n => n.parent()), -]); -*/ - -const buildHeirarchalIndex = async (app, indexNode) => { - let recordCount = 0; - - const createTransactionsForIds = async (collectionKey, ids) => { - for (const recordId of ids) { - const recordKey = joinKey(collectionKey, recordId); - - const recordNode = getRecordNodeById( - app.hierarchy, - recordId, - ); - - if (recordNodeApplies(indexNode)(recordNode)) { - await transactionForBuildIndex( - app, indexNode.nodeKey(), - recordKey, recordCount, - ); - recordCount++; - } - } - }; - - - const collectionRecords = getAllowedRecordNodesForIndex(app.hierarchy, indexNode); - - for (const targetCollectionRecordNode of collectionRecords) { - const allIdsIterator = await getAllIdsIterator(app)(targetCollectionRecordNode.collectionNodeKey()); - - let allIds = await allIdsIterator(); - while (allIds.done === false) { - await createTransactionsForIds( - allIds.result.collectionKey, - allIds.result.ids, - ); - allIds = await allIdsIterator(); - } - } - - return recordCount; -}; - -// const chooseChildRecordNodeByKey = (collectionNode, recordId) => find(c => recordId.startsWith(c.nodeId))(collectionNode.children); - -const recordNodeApplies = indexNode => recordNode => includes(recordNode.nodeId)(indexNode.allowedRecordNodeIds); - -const aggregates = app => async (indexKey, rangeStartParams = null, rangeEndParams = null) => apiWrapper( - app, - events.indexApi.aggregates, - permission.readIndex.isAuthorized(indexKey), - { indexKey, rangeStartParams, rangeEndParams }, - _aggregates, app, indexKey, rangeStartParams, rangeEndParams, -); - -const _aggregates = async (app, indexKey, rangeStartParams, rangeEndParams) => { - indexKey = safeKey(indexKey); - const indexNode = getExactNodeForKey(app.hierarchy)(indexKey); - const indexDir = getIndexDir(app.hierarchy, indexKey); - - if (!isIndex(indexNode)) { throw new BadRequestError('supplied key is not an index'); } - - if (isShardedIndex(indexNode)) { - const shardKeys = await getShardKeysInRange( - app, indexNode, indexDir, rangeStartParams, rangeEndParams, - ); - let aggregateResult = null; - for (const k of shardKeys) { - const shardResult = await getAggregates(app.hierarchy, app.datastore, indexNode, k); - if (aggregateResult === null) { - aggregateResult = shardResult; - } else { - aggregateResult = mergeShardAggregate( - aggregateResult, - shardResult, - ); - } - } - return aggregateResult; - } - return await getAggregates( - app.hierarchy, - app.datastore, - indexNode, - getUnshardedIndexDataKey(indexDir), - ); -}; - -const mergeShardAggregate = (totals, shard) => { - const mergeGrouping = (tot, shr) => { - tot.count += shr.count; - for (const aggName in tot) { - if (aggName === 'count') continue; - const totagg = tot[aggName]; - const shragg = shr[aggName]; - totagg.sum += shragg.sum; - totagg.max = totagg.max > shragg.max - ? totagg.max - : shragg.max; - totagg.min = totagg.min < shragg.min - ? totagg.min - : shragg.min; - totagg.mean = totagg.sum / tot.count; - } - return tot; - }; - - for (const aggGroupDef in totals) { - for (const grouping in shard[aggGroupDef]) { - const groupingTotal = totals[aggGroupDef][grouping]; - totals[aggGroupDef][grouping] = isUndefined(groupingTotal) - ? shard[aggGroupDef][grouping] - : mergeGrouping( - totals[aggGroupDef][grouping], - shard[aggGroupDef][grouping], - ); - } - } - - return totals; -}; - -const getAggregates = async (hierarchy, datastore, index, indexedDataKey) => { - const aggregateResult = {}; - const doRead = iterateIndex( - async item => { - applyItemToAggregateResult( - index, aggregateResult, item, - ); - return CONTINUE_READING_RECORDS; - }, - async () => aggregateResult - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); -}; - - -const applyItemToAggregateResult = (indexNode, result, item) => { - const getInitialAggregateResult = () => ({ - sum: 0, mean: null, max: null, min: null, - }); - - const applyAggregateResult = (agg, existing, count) => { - const value = compileCode$1(agg.aggregatedValue)({ record: item }); - - if (!isNumber(value)) return existing; - - existing.sum += value; - existing.max = value > existing.max || existing.max === null - ? value - : existing.max; - existing.min = value < existing.min || existing.min === null - ? value - : existing.min; - existing.mean = existing.sum / count; - return existing; - }; - - for (const aggGroup of indexNode.aggregateGroups) { - if (!has(aggGroup.name)(result)) { - result[aggGroup.name] = {}; - } - - const thisGroupResult = result[aggGroup.name]; - - if (isNonEmptyString(aggGroup.condition)) { - if (!compileExpression$1(aggGroup.condition)({ record: item })) { - continue; - } - } - - let group = isNonEmptyString(aggGroup.groupBy) - ? compileCode$1(aggGroup.groupBy)({ record: item }) - : 'all'; - if (!isNonEmptyString(group)) { - group = '(none)'; - } - - if (!has(group)(thisGroupResult)) { - thisGroupResult[group] = { count: 0 }; - for (const agg of aggGroup.aggregates) { - thisGroupResult[group][agg.name] = getInitialAggregateResult(); - } - } - - thisGroupResult[group].count++; - - for (const agg of aggGroup.aggregates) { - const existingValues = thisGroupResult[group][agg.name]; - thisGroupResult[group][agg.name] = applyAggregateResult( - agg, existingValues, - thisGroupResult[group].count, - ); - } - } -}; - -const getIndexApi = app => ({ - listItems: listItems(app), - buildIndex: buildIndex(app), - aggregates: aggregates(app), -}); - -const createNodeErrors = { - indexCannotBeParent: 'Index template cannot be a parent', - allNonRootNodesMustHaveParent: 'Only the root node may have no parent', - indexParentMustBeRecordOrRoot: 'An index may only have a record or root as a parent', - aggregateParentMustBeAnIndex: 'aggregateGroup parent must be an index', -}; - -const pathRegxMaker = node => () => node.nodeKey().replace(/{id}/g, '[a-zA-Z0-9_-]+'); - -const nodeKeyMaker = node => () => switchCase( - - [n => isRecord(n) && !isSingleRecord(n), - n => joinKey( - node.parent().nodeKey(), - node.collectionName, - `${n.nodeId}-{id}`, - )], - - [isRoot, - constant('/')], - - [defaultCase, - n => joinKey(node.parent().nodeKey(), n.name)], - -)(node); - - -const validate$1 = parent => (node) => { - if (isIndex(node) - && isSomething(parent) - && !isRoot(parent) - && !isRecord(parent)) { - throw new BadRequestError(createNodeErrors.indexParentMustBeRecordOrRoot); - } - - if (isaggregateGroup(node) - && isSomething(parent) - && !isIndex(parent)) { - throw new BadRequestError(createNodeErrors.aggregateParentMustBeAnIndex); - } - - if (isNothing(parent) && !isRoot(node)) { throw new BadRequestError(createNodeErrors.allNonRootNodesMustHaveParent); } - - return node; -}; - -const construct = parent => (node) => { - node.nodeKey = nodeKeyMaker(node); - node.pathRegx = pathRegxMaker(node); - node.parent = constant(parent); - node.isRoot = () => isNothing(parent) - && node.name === 'root' - && node.type === 'root'; - if (isCollectionRecord(node)) { - node.collectionNodeKey = () => joinKey( - parent.nodeKey(), node.collectionName, - ); - node.collectionPathRegx = () => joinKey( - parent.pathRegx(), node.collectionName, - ); - } - return node; -}; - -const addToParent = (obj) => { - const parent = obj.parent(); - if (isSomething(parent)) { - if (isIndex(obj)) - // Q: why are indexes not children ? - // A: because they cannot have children of their own. - { - parent.indexes.push(obj); - } - else if (isaggregateGroup(obj)) - { - parent.aggregateGroups.push(obj); - } else { - parent.children.push(obj); - } - - if (isRecord(obj)) { - const defaultIndex = find$1( - parent.indexes, - i => i.name === `${parent.name}_index`, - ); - if (defaultIndex) { - defaultIndex.allowedRecordNodeIds.push(obj.nodeId); - } - } - } - return obj; -}; - -const constructNode = (parent, obj) => $(obj, [ - construct(parent), - validate$1(parent), - addToParent, -]); - -const getNodeId = (parentNode) => { - // this case is handled better elsewhere - if (!parentNode) return null; - const findRoot = n => (isRoot(n) ? n : findRoot(n.parent())); - const root = findRoot(parentNode); - - return ($(root, [ - getFlattenedHierarchy, - map(n => n.nodeId), - max]) + 1); -}; - -const constructHierarchy = (node, parent) => { - construct(parent)(node); - if (node.indexes) { - each$1(node.indexes, - child => constructHierarchy(child, node)); - } - if (node.aggregateGroups) { - each$1(node.aggregateGroups, - child => constructHierarchy(child, node)); - } - if (node.children && node.children.length > 0) { - each$1(node.children, - child => constructHierarchy(child, node)); - } - if (node.fields) { - each$1(node.fields, - f => each$1(f.typeOptions, (val, key) => { - const def = all$1[f.type].optionDefinitions[key]; - if (!def) { - // unknown typeOption - delete f.typeOptions[key]; - } else { - f.typeOptions[key] = def.parse(val); - } - })); - } - return node; -}; - - -const getNewRootLevel = () => construct()({ - name: 'root', - type: 'root', - children: [], - pathMaps: [], - indexes: [], - nodeId: 0, -}); - -const _getNewRecordTemplate = (parent, name, createDefaultIndex, isSingle) => { - const node = constructNode(parent, { - name, - type: 'record', - fields: [], - children: [], - validationRules: [], - nodeId: getNodeId(parent), - indexes: [], - estimatedRecordCount: isRecord(parent) ? 500 : 1000000, - collectionName: '', - isSingle, - }); - - if (createDefaultIndex) { - const defaultIndex = getNewIndexTemplate(parent); - defaultIndex.name = `${name}_index`; - defaultIndex.allowedRecordNodeIds.push(node.nodeId); - } - - return node; -}; - -const getNewRecordTemplate = (parent, name = '', createDefaultIndex = true) => _getNewRecordTemplate(parent, name, createDefaultIndex, false); - -const getNewSingleRecordTemplate = parent => _getNewRecordTemplate(parent, '', false, true); - -const getNewIndexTemplate = (parent, type = 'ancestor') => constructNode(parent, { - name: '', - type: 'index', - map: 'return {...record};', - filter: '', - indexType: type, - getShardName: '', - getSortKey: 'record.id', - aggregateGroups: [], - allowedRecordNodeIds: [], - nodeId: getNodeId(parent), -}); - -const getNewAggregateGroupTemplate = index => constructNode(index, { - name: '', - type: 'aggregateGroup', - groupBy: '', - aggregates: [], - condition: '', - nodeId: getNodeId(index), -}); - -const getNewAggregateTemplate = (set) => { - const aggregatedValue = { - name: '', - aggregatedValue: '', - }; - set.aggregates.push(aggregatedValue); - return aggregatedValue; -}; - -const fieldErrors = { - AddFieldValidationFailed: 'Add field validation: ', -}; - -const allowedTypes = () => keys(all$1); - -const getNewField = type => ({ - name: '', // how field is referenced internally - type, - typeOptions: getDefaultOptions$1(type), - label: '', // how field is displayed - getInitialValue: 'default', // function that gets value when initially created - getUndefinedValue: 'default', // function that gets value when field undefined on record -}); - -const fieldRules = allFields => [ - makerule('name', 'field name is not set', - f => isNonEmptyString(f.name)), - makerule('type', 'field type is not set', - f => isNonEmptyString(f.type)), - makerule('label', 'field label is not set', - f => isNonEmptyString(f.label)), - makerule('getInitialValue', 'getInitialValue function is not set', - f => isNonEmptyString(f.getInitialValue)), - makerule('getUndefinedValue', 'getUndefinedValue function is not set', - f => isNonEmptyString(f.getUndefinedValue)), - makerule('name', 'field name is duplicated', - f => isNothingOrEmpty(f.name) - || countBy('name')(allFields)[f.name] === 1), - makerule('type', 'type is unknown', - f => isNothingOrEmpty(f.type) - || some(t => f.type === t)(allowedTypes())), -]; - -const typeOptionsRules = (field) => { - const type = all$1[field.type]; - if (isNothing(type)) return []; - - const def = optName => type.optionDefinitions[optName]; - - return $(field.typeOptions, [ - keys, - filter(o => isSomething(def(o)) - && isSomething(def(o).isValid)), - map(o => makerule( - `typeOptions.${o}`, - `${def(o).requirementDescription}`, - field => def(o).isValid(field.typeOptions[o]), - )), - ]); -}; - -const validateField = allFields => (field) => { - const everySingleField = includes(field)(allFields) ? allFields : [...allFields, field]; - return applyRuleSet([...fieldRules(everySingleField), ...typeOptionsRules(field)])(field); -}; - -const validateAllFields = recordNode => $(recordNode.fields, [ - map(validateField(recordNode.fields)), - flatten, -]); - -const addField = (recordTemplate, field) => { - if (isNothingOrEmpty(field.label)) { - field.label = field.name; - } - const validationMessages = validateField([...recordTemplate.fields, field])(field); - if (validationMessages.length > 0) { - const errors = map(m => m.error)(validationMessages); - throw new BadRequestError(`${fieldErrors.AddFieldValidationFailed} ${errors.join(', ')}`); - } - recordTemplate.fields.push(field); -}; - -const getNewRecordValidationRule = (invalidFields, - messageWhenInvalid, - expressionWhenValid) => ({ - invalidFields, messageWhenInvalid, expressionWhenValid, -}); - -const getStaticValue = switchCase( - [isNumber, v => v.toString()], - [isBoolean, v => v.toString()], - [defaultCase$1, v => `'${v}'`], -); - -const commonRecordValidationRules = ({ - - fieldNotEmpty: fieldName => getNewRecordValidationRule( - [fieldName], - `${fieldName} is empty`, - `!_.isEmpty(record['${fieldName}'])`, - ), - - fieldBetween: (fieldName, min, max) => getNewRecordValidationRule( - [fieldName], - `${fieldName} must be between ${min.toString()} and ${max.toString()}`, - `record['${fieldName}'] >= ${getStaticValue(min)} && record['${fieldName}'] <= ${getStaticValue(max)} `, - ), - - fieldGreaterThan: (fieldName, min, max) => getNewRecordValidationRule( - [fieldName], - `${fieldName} must be greater than ${min.toString()} and ${max.toString()}`, - `record['${fieldName}'] >= ${getStaticValue(min)} `, - ), -}); - -const addRecordValidationRule = recordNode => rule => recordNode.validationRules.push(rule); - -const createTrigger = () => ({ - actionName: '', - eventName: '', - // function, has access to event context, - // returns object that is used as parameter to action - // only used if triggered by event - optionsCreator: '', - // action runs if true, - // has access to event context - condition: '', -}); - -const createAction = () => ({ - name: '', - behaviourSource: '', - // name of function in actionSource - behaviourName: '', - // parameter passed into behaviour. - // any other parms passed at runtime e.g. - // by trigger, or manually, will be merged into this - initialOptions: {}, -}); - -const aggregateRules = [ - makerule('name', 'choose a name for the aggregate', - a => isNonEmptyString(a.name)), - makerule('aggregatedValue', 'aggregatedValue does not compile', - a => isEmpty(a.aggregatedValue) - || executesWithoutException( - () => compileCode$1(a.aggregatedValue), - )), -]; - -const validateAggregate = aggregate => applyRuleSet(aggregateRules)(aggregate); - -const validateAllAggregates = all => $(all, [ - map(validateAggregate), - flatten, -]); - -const ruleSet = (...sets) => constant(flatten([...sets])); - -const commonRules = [ - makerule('name', 'node name is not set', - node => stringNotEmpty(node.name)), - makerule('type', 'node type not recognised', - anyTrue(isRecord, isRoot, isIndex, isaggregateGroup)), -]; - -const recordRules = [ - makerule('fields', 'no fields have been added to the record', - node => isNonEmptyArray(node.fields)), - makerule('validationRules', "validation rule is missing a 'messageWhenValid' member", - node => every(r => has('messageWhenInvalid')(r))(node.validationRules)), - makerule('validationRules', "validation rule is missing a 'expressionWhenValid' member", - node => every(r => has('expressionWhenValid')(r))(node.validationRules)), -]; - - -const aggregateGroupRules = [ - makerule('condition', 'condition does not compile', - a => isEmpty(a.condition) - || executesWithoutException( - () => compileExpression$1(a.condition), - )), -]; - -const getRuleSet = node => switchCase( - - [isRecord, ruleSet( - commonRules, - recordRules, - )], - - [isIndex, ruleSet( - commonRules, - indexRuleSet, - )], - - [isaggregateGroup, ruleSet( - commonRules, - aggregateGroupRules, - )], - - [defaultCase, ruleSet(commonRules, [])], -)(node); - -const validateNode = node => applyRuleSet(getRuleSet(node))(node); - -const validateAll = (appHierarchy) => { - const flattened = getFlattenedHierarchy( - appHierarchy, - ); - - const duplicateNameRule = makerule( - 'name', 'node names must be unique under shared parent', - n => filter(f => f.parent() === n.parent() - && f.name === n.name)(flattened).length === 1, - ); - - const duplicateNodeKeyErrors = $(flattened, [ - map(n => applyRuleSet([duplicateNameRule])(n)), - filter(isSomething), - flatten, - ]); - - const fieldErrors = $(flattened, [ - filter(isRecord), - map(validateAllFields), - flatten, - ]); - - const aggregateErrors = $(flattened, [ - filter(isaggregateGroup), - map(s => validateAllAggregates( - s.aggregates, - )), - flatten, - ]); - - return $(flattened, [ - map(validateNode), - flatten, - union(duplicateNodeKeyErrors), - union(fieldErrors), - union(aggregateErrors), - ]); -}; - -const actionRules = [ - makerule('name', 'action must have a name', - a => isNonEmptyString(a.name)), - makerule('behaviourName', 'must supply a behaviour name to the action', - a => isNonEmptyString(a.behaviourName)), - makerule('behaviourSource', 'must supply a behaviour source for the action', - a => isNonEmptyString(a.behaviourSource)), -]; - -const duplicateActionRule = makerule('', 'action name must be unique', () => {}); - -const validateAction = action => applyRuleSet(actionRules)(action); - - -const validateActions = (allActions) => { - const duplicateActions = $(allActions, [ - filter(a => filter(a2 => a2.name === a.name)(allActions).length > 1), - map(a => validationError(duplicateActionRule, a)), - ]); - - const errors = $(allActions, [ - map(validateAction), - flatten, - union(duplicateActions), - uniqBy('name'), - ]); - - return errors; -}; - -const triggerRules = actions => ([ - makerule('actionName', 'must specify an action', - t => isNonEmptyString(t.actionName)), - makerule('eventName', 'must specify and event', - t => isNonEmptyString(t.eventName)), - makerule('actionName', 'specified action not supplied', - t => !t.actionName - || some(a => a.name === t.actionName)(actions)), - makerule('eventName', 'invalid Event Name', - t => !t.eventName - || includes(t.eventName)(eventsList)), - makerule('optionsCreator', 'Options Creator does not compile - check your expression', - (t) => { - if (!t.optionsCreator) return true; - try { - compileCode$1(t.optionsCreator); - return true; - } catch (_) { return false; } - }), - makerule('condition', 'Trigger condition does not compile - check your expression', - (t) => { - if (!t.condition) return true; - try { - compileExpression$1(t.condition); - return true; - } catch (_) { return false; } - }), -]); - -const validateTrigger = (trigger, allActions) => { - const errors = applyRuleSet(triggerRules(allActions))(trigger); - - return errors; -}; - -const validateTriggers = (triggers, allActions) => $(triggers, [ - map(t => validateTrigger(t, allActions)), - flatten, -]); - -const getApplicationDefinition = datastore => async () => { - const exists = await datastore.exists(appDefinitionFile); - - if (!exists) throw new Error('Application definition does not exist'); - - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.hierarchy = constructHierarchy( - appDefinition.hierarchy, - ); - return appDefinition; -}; - -const saveApplicationHierarchy = app => async hierarchy => apiWrapper( - app, - events.templateApi.saveApplicationHierarchy, - permission.writeTemplates.isAuthorized, - { hierarchy }, - _saveApplicationHierarchy, app.datastore, hierarchy, -); - - -const _saveApplicationHierarchy = async (datastore, hierarchy) => { - const validationErrors = await validateAll(hierarchy); - if (validationErrors.length > 0) { - throw new Error(`Hierarchy is invalid: ${join$2( - validationErrors.map(e => `${e.item.nodeKey ? e.item.nodeKey() : ''} : ${e.error}`), - ',', - )}`); - } - - if (await datastore.exists(appDefinitionFile)) { - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.hierarchy = hierarchy; - await datastore.updateJson(appDefinitionFile, appDefinition); - } else { - await datastore.createFolder('/.config'); - const appDefinition = { actions: [], triggers: [], hierarchy }; - await datastore.createJson(appDefinitionFile, appDefinition); - } -}; - -const saveActionsAndTriggers = app => async (actions, triggers) => apiWrapper( - app, - events.templateApi.saveActionsAndTriggers, - permission.writeTemplates.isAuthorized, - { actions, triggers }, - _saveActionsAndTriggers, app.datastore, actions, triggers, -); - -const _saveActionsAndTriggers = async (datastore, actions, triggers) => { - if (await datastore.exists(appDefinitionFile)) { - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.actions = actions; - appDefinition.triggers = triggers; - - const actionValidErrs = map(e => e.error)(validateActions(actions)); - - if (actionValidErrs.length > 0) { - throw new BadRequestError(`Actions are invalid: ${join$2(actionValidErrs, ', ')}`); - } - - const triggerValidErrs = map(e => e.error)(validateTriggers(triggers, actions)); - - if (triggerValidErrs.length > 0) { - throw new BadRequestError(`Triggers are invalid: ${join$2(triggerValidErrs, ', ')}`); - } - - await datastore.updateJson(appDefinitionFile, appDefinition); - } else { - throw new BadRequestError('Cannot save actions: Application definition does not exist'); - } -}; - -const getBehaviourSources = async (datastore) => { - await datastore.loadFile('/.config/behaviourSources.js'); -}; - -const api$1 = app => ({ - - getApplicationDefinition: getApplicationDefinition(app.datastore), - saveApplicationHierarchy: saveApplicationHierarchy(app), - saveActionsAndTriggers: saveActionsAndTriggers(app), - getBehaviourSources: () => getBehaviourSources(app.datastore), - getNewRootLevel, - constructNode, - getNewIndexTemplate, - getNewRecordTemplate, - getNewField, - validateField, - addField, - fieldErrors, - getNewRecordValidationRule, - commonRecordValidationRules, - addRecordValidationRule, - createAction, - createTrigger, - validateActions, - validateTrigger, - getNewAggregateGroupTemplate, - getNewAggregateTemplate, - constructHierarchy, - getNewSingleRecordTemplate, - allTypes: all$1, - validateNode, - validateAll, - validateTriggers, -}); - - -const getTemplateApi = app => api$1(app); - -const getUsers = app => async () => apiWrapper( - app, - events.authApi.getUsers, - permission.listUsers.isAuthorized, - {}, - _getUsers, app, -); - -const _getUsers = async app => $(await app.datastore.loadJson(USERS_LIST_FILE), [ - map(stripUserOfSensitiveStuff), -]); - -const loadAccessLevels = app => async () => apiWrapper( - app, - events.authApi.loadAccessLevels, - permission.listAccessLevels.isAuthorized, - {}, - _loadAccessLevels, app, -); - -const _loadAccessLevels = async app => await app.datastore.loadJson(ACCESS_LEVELS_FILE); - -const dummyHash = '$argon2i$v=19$m=4096,t=3,p=1$UZRo409UYBGjHJS3CV6Uxw$rU84qUqPeORFzKYmYY0ceBLDaPO+JWSH4PfNiKXfIKk'; - -const authenticate = app => async (username, password) => apiWrapper( - app, - events.authApi.authenticate, - alwaysAuthorized, - { username, password }, - _authenticate, app, username, password, -); - -const _authenticate = async (app, username, password) => { - if (isNothingOrEmpty(username) || isNothingOrEmpty(password)) { return null; } - - const allUsers = await _getUsers(app); - let user = getUserByName( - allUsers, - username, - ); - - const notAUser = 'not-a-user'; - // continue with non-user - so time to verify remains consistent - // with verification of a valid user - if (!user || !user.enabled) { user = notAUser; } - - let userAuth; - try { - userAuth = await app.datastore.loadJson( - userAuthFile(username), - ); - } catch (_) { - userAuth = { accessLevels: [], passwordHash: dummyHash }; - } - - const permissions = await buildUserPermissions(app, user.accessLevels); - - const verified = await app.crypto.verify( - userAuth.passwordHash, - password, - ); - - if (user === notAUser) { return null; } - - return verified - ? { - ...user, permissions, temp: false, isUser: true, - } - : null; -}; - -const authenticateTemporaryAccess = app => async (tempAccessCode) => { - if (isNothingOrEmpty(tempAccessCode)) { return null; } - - const temp = parseTemporaryCode(tempAccessCode); - let user = $(await _getUsers(app), [ - find(u => u.temporaryAccessId === temp.id), - ]); - - const notAUser = 'not-a-user'; - if (!user || !user.enabled) { user = notAUser; } - - let userAuth; - try { - userAuth = await app.datastore.loadJson( - userAuthFile(user.name), - ); - } catch (e) { - userAuth = { - temporaryAccessHash: dummyHash, - temporaryAccessExpiryEpoch: (await app.getEpochTime() + 10000), - }; - } - - if (userAuth.temporaryAccessExpiryEpoch < await app.getEpochTime()) { user = notAUser; } - - const tempCode = !temp.code ? generate() : temp.code; - const verified = await app.crypto.verify( - userAuth.temporaryAccessHash, - tempCode, - ); - - if (user === notAUser) { return null; } - - return verified - ? { - ...user, - permissions: [], - temp: true, - isUser: true, - } - : null; -}; - -const buildUserPermissions = async (app, userAccessLevels) => { - const allAccessLevels = await _loadAccessLevels(app); - - return $(allAccessLevels.levels, [ - filter(l => some(ua => l.name === ua)(userAccessLevels)), - map(l => l.permissions), - flatten, - ]); -}; - -const createTemporaryAccess$1 = app => async userName => apiWrapper( - app, - events.authApi.createTemporaryAccess, - alwaysAuthorized, - { userName }, - _createTemporaryAccess, app, userName, -); - -const _createTemporaryAccess = async (app, userName) => { - const tempCode = await getTemporaryCode(app); - - const lock = await getLock( - app, USERS_LOCK_FILE, 1000, 2, - ); - - if (isNolock(lock)) { throw new Error('Unable to create temporary access, could not get lock - try again'); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - - const user = getUserByName(users, userName); - user.temporaryAccessId = tempCode.temporaryAccessId; - - await app.datastore.updateJson( - USERS_LIST_FILE, - users, - ); - } finally { - await releaseLock(app, lock); - } - - const userAuth = await app.datastore.loadJson( - userAuthFile(userName), - ); - userAuth.temporaryAccessHash = tempCode.temporaryAccessHash; - - userAuth.temporaryAccessExpiryEpoch = tempCode.temporaryAccessExpiryEpoch; - - await app.datastore.updateJson( - userAuthFile(userName), - userAuth, - ); - - return tempCode.tempCode; -}; - -const getTemporaryCode = async (app) => { - const tempCode = generate() - + generate() - + generate() - + generate(); - - const tempId = generate(); - - return { - temporaryAccessHash: await app.crypto.hash( - tempCode, - ), - temporaryAccessExpiryEpoch: - (await app.getEpochTime()) + tempCodeExpiryLength, - tempCode: `tmp:${tempId}:${tempCode}`, - temporaryAccessId: tempId, - }; -}; - -const userRules = allUsers => [ - makerule('name', 'username must be set', - u => isNonEmptyString(u.name)), - makerule('accessLevels', 'user must have at least one access level', - u => u.accessLevels.length > 0), - makerule('name', 'username must be unique', - u => filter(u2 => insensitiveEquals(u2.name, u.name))(allUsers).length === 1), - makerule('accessLevels', 'access levels must only contain stings', - u => all(isNonEmptyString)(u.accessLevels)), -]; - -const validateUser = () => (allusers, user) => applyRuleSet(userRules(allusers))(user); - -const getNewUser = app => () => apiWrapperSync( - app, - events.authApi.getNewUser, - permission.createUser.isAuthorized, - {}, - _getNewUser, app, -); - -const _getNewUser = () => ({ - name: '', - accessLevels: [], - enabled: true, - temporaryAccessId: '', -}); - -const getNewUserAuth = app => () => apiWrapperSync( - app, - events.authApi.getNewUserAuth, - permission.createUser.isAuthorized, - {}, - _getNewUserAuth, app, -); - -const _getNewUserAuth = () => ({ - passwordHash: '', - temporaryAccessHash: '', - temporaryAccessExpiryEpoch: 0, -}); - -const isValidPassword = app => password => apiWrapperSync( - app, - events.authApi.isValidPassword, - alwaysAuthorized, - { password }, - _isValidPassword, app, password, -); - -const _isValidPassword = (app, password) => scorePassword(password).score > 30; - -const changeMyPassword = app => async (currentPw, newpassword) => apiWrapper( - app, - events.authApi.changeMyPassword, - alwaysAuthorized, - { currentPw, newpassword }, - _changeMyPassword, app, currentPw, newpassword, -); - -const _changeMyPassword = async (app, currentPw, newpassword) => { - const existingAuth = await app.datastore.loadJson( - userAuthFile(app.user.name), - ); - - if (isSomething(existingAuth.passwordHash)) { - const verified = await app.crypto.verify( - existingAuth.passwordHash, - currentPw, - ); - - if (verified) { - await await doSet( - app, existingAuth, - app.user.name, newpassword, - ); - return true; - } - } - - return false; -}; - -const setPasswordFromTemporaryCode = app => async (tempCode, newpassword) => apiWrapper( - app, - events.authApi.setPasswordFromTemporaryCode, - alwaysAuthorized, - { tempCode, newpassword }, - _setPasswordFromTemporaryCode, app, tempCode, newpassword, -); - - -const _setPasswordFromTemporaryCode = async (app, tempCode, newpassword) => { - const currentTime = await app.getEpochTime(); - - const temp = parseTemporaryCode(tempCode); - - const user = $(await _getUsers(app), [ - find(u => u.temporaryAccessId === temp.id), - ]); - - if (!user) { return false; } - - const existingAuth = await app.datastore.loadJson( - userAuthFile(user.name), - ); - - if (isSomething(existingAuth.temporaryAccessHash) - && existingAuth.temporaryAccessExpiryEpoch > currentTime) { - const verified = await app.crypto.verify( - existingAuth.temporaryAccessHash, - temp.code, - ); - - if (verified) { - await doSet( - app, existingAuth, - user.name, newpassword, - ); - return true; - } - } - - return false; -}; - -const doSet = async (app, auth, username, newpassword) => { - auth.temporaryAccessHash = ''; - auth.temporaryAccessExpiryEpoch = 0; - auth.passwordHash = await app.crypto.hash( - newpassword, - ); - await app.datastore.updateJson( - userAuthFile(username), - auth, - ); -}; - -const scorePassword = app => password => apiWrapperSync( - app, - events.authApi.scorePassword, - alwaysAuthorized, - { password }, - _scorePassword, password, -); - -const _scorePassword = (password) => { - // from https://stackoverflow.com/questions/948172/password-strength-meter - // thank you https://stackoverflow.com/users/46617/tm-lv - - let score = 0; - if (!password) { return score; } - - // award every unique letter until 5 repetitions - const letters = new Object(); - for (let i = 0; i < password.length; i++) { - letters[password[i]] = (letters[password[i]] || 0) + 1; - score += 5.0 / letters[password[i]]; - } - - // bonus points for mixing it up - const variations = { - digits: /\d/.test(password), - lower: /[a-z]/.test(password), - upper: /[A-Z]/.test(password), - nonWords: /\W/.test(password), - }; - - let variationCount = 0; - for (const check in variations) { - variationCount += (variations[check] == true) ? 1 : 0; - } - score += (variationCount - 1) * 10; - - const strengthText = score > 80 - ? 'strong' - : score > 60 - ? 'good' - : score >= 30 - ? 'weak' - : 'very weak'; - - return { - score: parseInt(score), - strengthText, - }; -}; - -const createUser$1 = app => async (user, password = null) => apiWrapper( - app, - events.authApi.createUser, - permission.createUser.isAuthorized, - { user, password }, - _createUser, app, user, password, -); - -const _createUser = async (app, user, password = null) => { - const lock = await getLock( - app, USERS_LOCK_FILE, 1000, 2, - ); - - if (isNolock(lock)) { throw new Error('Unable to create user, could not get lock - try again'); } - - const users = await app.datastore.loadJson(USERS_LIST_FILE); - - const userErrors = validateUser()([...users, user], user); - if (userErrors.length > 0) { throw new BadRequestError(`User is invalid. ${join$1('; ')(userErrors)}`); } - - const { auth, tempCode, temporaryAccessId } = await getAccess( - app, password, - ); - user.tempCode = tempCode; - user.temporaryAccessId = temporaryAccessId; - - if (some(u => insensitiveEquals(u.name, user.name))(users)) { - throw new BadRequestError('User already exists'); - } - - users.push( - stripUserOfSensitiveStuff(user), - ); - - await app.datastore.updateJson( - USERS_LIST_FILE, - users, - ); - - try { - await app.datastore.createJson( - userAuthFile(user.name), - auth, - ); - } catch (_) { - await app.datastore.updateJson( - userAuthFile(user.name), - auth, - ); - } - - await releaseLock(app, lock); - - return user; -}; - -const getAccess = async (app, password) => { - const auth = getNewUserAuth(app)(); - - if (isNonEmptyString(password)) { - if (isValidPassword(password)) { - auth.passwordHash = await app.crypto.hash(password); - auth.temporaryAccessHash = ''; - auth.temporaryAccessId = ''; - auth.temporaryAccessExpiryEpoch = 0; - return { auth }; - } - throw new BadRequestError('Password does not meet requirements'); - } else { - const tempAccess = await getTemporaryCode(app); - auth.temporaryAccessHash = tempAccess.temporaryAccessHash; - auth.temporaryAccessExpiryEpoch = tempAccess.temporaryAccessExpiryEpoch; - auth.passwordHash = ''; - return ({ - auth, - tempCode: tempAccess.tempCode, - temporaryAccessId: tempAccess.temporaryAccessId, - }); - } -}; - -const enableUser = app => async username => apiWrapper( - app, - events.authApi.enableUser, - permission.enableDisableUser.isAuthorized, - { username }, - _enableUser, app, username, -); - -const disableUser = app => async username => apiWrapper( - app, - events.authApi.disableUser, - permission.enableDisableUser.isAuthorized, - { username }, - _disableUser, app, username, -); - -const _enableUser = async (app, username) => await toggleUser(app, username, true); - -const _disableUser = async (app, username) => await toggleUser(app, username, false); - -const toggleUser = async (app, username, enabled) => { - const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0); - - const actionName = enabled ? 'enable' : 'disable'; - - if (isNolock(lock)) { throw new Error(`Could not ${actionName} user - cannot get lock`); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - const user = getUserByName(users, username); - if (!user) { throw new NotFoundError(`Could not find user to ${actionName}`); } - - if (user.enabled === !enabled) { - user.enabled = enabled; - await app.datastore.updateJson(USERS_LIST_FILE, users); - } - } finally { - releaseLock(app, lock); - } -}; - -const getNewAccessLevel = () => () => ({ - name: '', - permissions: [], - default:false -}); - -const isAllowedType = t => $(permissionTypes, [ - values, - includes(t), -]); - -const isRecordOrIndexType = t => some(p => p === t)([ - permissionTypes.CREATE_RECORD, - permissionTypes.UPDATE_RECORD, - permissionTypes.DELETE_RECORD, - permissionTypes.READ_RECORD, - permissionTypes.READ_INDEX, - permissionTypes.EXECUTE_ACTION, -]); - - -const permissionRules = app => ([ - makerule('type', 'type must be one of allowed types', - p => isAllowedType(p.type)), - makerule('nodeKey', 'record and index permissions must include a valid nodeKey', - p => (!isRecordOrIndexType(p.type)) - || isSomething(getNode(app.hierarchy, p.nodeKey))), -]); - -const applyPermissionRules = app => applyRuleSet(permissionRules(app)); - -const accessLevelRules = allLevels => ([ - makerule('name', 'name must be set', - l => isNonEmptyString(l.name)), - makerule('name', 'access level names must be unique', - l => isEmpty(l.name) - || filter(a => insensitiveEquals(l.name, a.name))(allLevels).length === 1), -]); - -const applyLevelRules = allLevels => applyRuleSet(accessLevelRules(allLevels)); - -const validateAccessLevel = app => (allLevels, level) => { - const errs = $(level.permissions, [ - map(applyPermissionRules(app)), - flatten, - concat( - applyLevelRules(allLevels)(level), - ), - ]); - - return errs; -}; - -const validateAccessLevels = app => allLevels => apiWrapperSync( - app, - events.authApi.validateAccessLevels, - alwaysAuthorized, - { allLevels }, - _validateAccessLevels, app, allLevels, -); - -const _validateAccessLevels = (app, allLevels) => $(allLevels, [ - map(l => validateAccessLevel(app)(allLevels, l)), - flatten, - uniqWith((x, y) => x.field === y.field - && x.item === y.item - && x.error === y.error), -]); - -const saveAccessLevels = app => async accessLevels => apiWrapper( - app, - events.authApi.saveAccessLevels, - permission.writeAccessLevels.isAuthorized, - { accessLevels }, - _saveAccessLevels, app, accessLevels, -); - -const _saveAccessLevels = async (app, accessLevels) => { - const validationErrors = validateAccessLevels(app)(accessLevels.levels); - if (validationErrors.length > 0) { - const errs = $(validationErrors, [ - map(e => e.error), - join$1(', '), - ]); - throw new Error( - `Access Levels Invalid: ${errs}`, - ); - } - - const lock = await getLock( - app, ACCESS_LEVELS_LOCK_FILE, 2000, 2, - ); - - if (isNolock(lock)) { throw new Error('Could not get lock to save access levels'); } - - try { - const existing = await app.datastore.loadJson(ACCESS_LEVELS_FILE); - if (existing.version !== accessLevels.version) { throw new Error('Access levels have already been updated, since you loaded'); } - - accessLevels.version++; - - app.datastore.updateJson(ACCESS_LEVELS_FILE, accessLevels); - } finally { - await releaseLock(app, lock); - } -}; - -const generateFullPermissions = (app) => { - const allNodes = getFlattenedHierarchy(app.hierarchy); - const accessLevel = { permissions: [] }; - - const recordNodes = $(allNodes, [ - filter(isRecord), - ]); - - for (const n of recordNodes) { - permission.createRecord.add(n.nodeKey(), accessLevel); - permission.updateRecord.add(n.nodeKey(), accessLevel); - permission.deleteRecord.add(n.nodeKey(), accessLevel); - permission.readRecord.add(n.nodeKey(), accessLevel); - } - - const indexNodes = $(allNodes, [ - filter(isIndex), - ]); - - for (const n of indexNodes) { - permission.readIndex.add(n.nodeKey(), accessLevel); - } - - for (const a of keys(app.actions)) { - permission.executeAction.add(a, accessLevel); - } - - $(permission, [ - values, - filter(p => !p.isNode), - each(p => p.add(accessLevel)), - ]); - - return accessLevel.permissions; -}; - -const setUserAccessLevels$1 = app => async (userName, accessLevels) => apiWrapper( - app, - events.authApi.setUserAccessLevels, - permission.setUserAccessLevels.isAuthorized, - { userName, accessLevels }, - _setUserAccessLevels, app, userName, accessLevels, -); - -const _setUserAccessLevels = async (app, username, accessLevels) => { - const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0); - - const actualAccessLevels = $( - await app.datastore.loadJson(ACCESS_LEVELS_FILE), - [ - l => l.levels, - map(l => l.name), - ], - ); - - const missing = difference(accessLevels)(actualAccessLevels); - if (missing.length > 0) { - throw new Error(`Invalid access levels supplied: ${join$1(', ', missing)}`); - } - - if (isNolock(lock)) { throw new Error('Could set user access levels cannot get lock'); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - const user = getUserByName(users, username); - if (!user) { throw new NotFoundError(`Could not find user with ${username}`); } - - user.accessLevels = accessLevels; - await app.datastore.updateJson(USERS_LIST_FILE, users); - } finally { - releaseLock(app, lock); - } -}; - -const getAuthApi = app => ({ - authenticate: authenticate(app), - authenticateTemporaryAccess: authenticateTemporaryAccess(app), - createTemporaryAccess: createTemporaryAccess$1(app), - createUser: createUser$1(app), - loadAccessLevels: loadAccessLevels(app), - enableUser: enableUser(app), - disableUser: disableUser(app), - getNewAccessLevel: getNewAccessLevel(), - getNewUser: getNewUser(app), - getNewUserAuth: getNewUserAuth(app), - getUsers: getUsers(app), - saveAccessLevels: saveAccessLevels(app), - isAuthorized: isAuthorized(app), - changeMyPassword: changeMyPassword(app), - setPasswordFromTemporaryCode: setPasswordFromTemporaryCode(app), - scorePassword, - isValidPassword: isValidPassword(app), - validateUser: validateUser(), - validateAccessLevels: validateAccessLevels(app), - generateFullPermissions: () => generateFullPermissions(app), - setUserAccessLevels: setUserAccessLevels$1(app), -}); - -const executeAction$1 = app => (actionName, options) => { - apiWrapperSync( - app, - events.actionsApi.execute, - permission.executeAction.isAuthorized(actionName), - { actionName, options }, - app.actions[actionName], options, - ); -}; - -const _executeAction = (behaviourSources, action, options) => behaviourSources[action.behaviourSource][action.behaviourName](options); - -const getActionsApi = app => ({ - execute: executeAction$1(app), -}); - -const publish = handlers => async (eventName, context = {}) => { - if (!has(eventName)(handlers)) return; - - for (const handler of handlers[eventName]) { - await handler(eventName, context); - } -}; - -const subscribe = handlers => (eventName, handler) => { - if (!has(eventName)(handlers)) { - handlers[eventName] = []; - } - handlers[eventName].push(handler); -}; - -const createEventAggregator = () => { - const handlers = {}; - const eventAggregator = ({ - publish: publish(handlers), - subscribe: subscribe(handlers), - }); - return eventAggregator; -}; - -const createJson = originalCreateFile => async (key, obj, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, key, JSON.stringify(obj)); - -const createNewFile = originalCreateFile => async (path, content, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, path, content); - -const loadJson = datastore => async (key, retries = 3, delay = 100) => { - try { - return await retry(JSON.parse, retries, delay, await datastore.loadFile(key)); - } catch (err) { - const newErr = new NotFoundError(err.message); - newErr.stack = err.stack; - throw(newErr); - } -}; - -const updateJson = datastore => async (key, obj, retries = 3, delay = 100) => { - try { - return await retry(datastore.updateFile, retries, delay, key, JSON.stringify(obj)); - } catch (err) { - const newErr = new NotFoundError(err.message); - newErr.stack = err.stack; - throw(newErr); - } -}; - -const setupDatastore = (datastore) => { - const originalCreateFile = datastore.createFile; - datastore.loadJson = loadJson(datastore); - datastore.createJson = createJson(originalCreateFile); - datastore.updateJson = updateJson(datastore); - datastore.createFile = createNewFile(originalCreateFile); - if (datastore.createEmptyDb) { delete datastore.createEmptyDb; } - return datastore; -}; - -const compileCode = code => { - let func; - - try { - func = compileCode$1(code); - } catch(e) { - e.message = `Error compiling code : ${code} : ${e.message}`; - throw e; - } - - return func; -}; - -const compileExpression = code => { - let func; - - try { - func = compileExpression$1(code); - } catch(e) { - e.message = `Error compiling expression : ${code} : ${e.message}`; - throw e; - } - - return func; -}; - -const initialiseActions = (subscribe, behaviourSources, actions, triggers, apis) => { - validateSources(behaviourSources, actions); - subscribeTriggers(subscribe, behaviourSources, actions, triggers, apis); - return createActionsCollection(behaviourSources, actions); -}; - -const createActionsCollection = (behaviourSources, actions) => $(actions, [ - reduce((all, a) => { - all[a.name] = opts => _executeAction(behaviourSources, a, opts); - return all; - }, {}), -]); - -const subscribeTriggers = (subscribe, behaviourSources, actions, triggers, apis) => { - const createOptions = (optionsCreator, eventContext) => { - if (!optionsCreator) return {}; - const create = compileCode(optionsCreator); - return create({ context: eventContext, apis }); - }; - - const shouldRunTrigger = (trigger, eventContext) => { - if (!trigger.condition) return true; - const shouldRun = compileExpression(trigger.condition); - return shouldRun({ context: eventContext }); - }; - - for (let trig of triggers) { - subscribe(trig.eventName, async (ev, ctx) => { - if (shouldRunTrigger(trig, ctx)) { - await _executeAction( - behaviourSources, - find(a => a.name === trig.actionName)(actions), - createOptions(trig.optionsCreator, ctx), - ); - } - }); - } -}; - -const validateSources = (behaviourSources, actions) => { - const declaredSources = $(actions, [ - uniqBy(a => a.behaviourSource), - map(a => a.behaviourSource), - ]); - - const suppliedSources = keys(behaviourSources); - - const missingSources = difference( - declaredSources, suppliedSources, - ); - - if (missingSources.length > 0) { - throw new BadRequestError(`Declared behaviour sources are not supplied: ${join$1(', ', missingSources)}`); - } - - const missingBehaviours = $(actions, [ - filter(a => !isFunction(behaviourSources[a.behaviourSource][a.behaviourName])), - map(a => `Action: ${a.name} : ${a.behaviourSource}.${a.behaviourName}`), - ]); - - if (missingBehaviours.length > 0) { - throw new NotFoundError(`Missing behaviours: could not find behaviour functions: ${join$1(', ', missingBehaviours)}`); - } -}; - -const retrieve = async (app) => { - const transactionFiles = await app.datastore.getFolderContents( - TRANSACTIONS_FOLDER, - ); - - let transactions = []; - - if (some(isBuildIndexFolder)(transactionFiles)) { - const buildIndexFolder = find(isBuildIndexFolder)(transactionFiles); - - transactions = await retrieveBuildIndexTransactions( - app, - joinKey(TRANSACTIONS_FOLDER, buildIndexFolder), - ); - } - - if (transactions.length > 0) return transactions; - - return await retrieveStandardTransactions( - app, transactionFiles, - ); -}; - -const retrieveBuildIndexTransactions = async (app, buildIndexFolder) => { - const childFolders = await app.datastore.getFolderContents(buildIndexFolder); - if (childFolders.length === 0) { - // cleanup - await app.datastore.deleteFolder(buildIndexFolder); - return []; - } - - const getTransactionFiles = async (childFolderIndex = 0) => { - if (childFolderIndex >= childFolders.length) return []; - - const childFolderKey = joinKey(buildIndexFolder, childFolders[childFolderIndex]); - const files = await app.datastore.getFolderContents( - childFolderKey, - ); - - if (files.length === 0) { - await app.datastore.deleteFolder(childFolderKey); - return await getTransactionFiles(childFolderIndex + 1); - } - - return { childFolderKey, files }; - }; - - const transactionFiles = await getTransactionFiles(); - - if (transactionFiles.files.length === 0) return []; - - const transactions = $(transactionFiles.files, [ - map(parseTransactionId), - ]); - - for (const t of transactions) { - const transactionContent = await app.datastore.loadJson( - joinKey( - transactionFiles.childFolderKey, - t.fullId, - ), - ); - t.record = await _load(app, transactionContent.recordKey); - } - - transactions.indexNode = $(buildIndexFolder, [ - getLastPartInKey, - nodeKeyHashFromBuildFolder, - getNodeFromNodeKeyHash(app.hierarchy), - ]); - - transactions.folderKey = transactionFiles.childFolderKey; - - return transactions; -}; - -const retrieveStandardTransactions = async (app, transactionFiles) => { - const transactionIds = $(transactionFiles, [ - filter(f => f !== LOCK_FILENAME - && !isBuildIndexFolder(f)), - map(parseTransactionId), - ]); - - const transactionIdsByRecord = $(transactionIds, [ - groupBy('recordId'), - ]); - - const dedupedTransactions = []; - - const verify = async (t) => { - if (t.verified === true) return t; - - const id = getTransactionId( - t.recordId, - t.transactionType, - t.uniqueId, - ); - - const transaction = await app.datastore.loadJson( - joinKey(TRANSACTIONS_FOLDER, id), - ); - - if (isDelete(t)) { - t.record = transaction.record; - t.verified = true; - return t; - } - - const rec = await _load( - app, - transaction.recordKey, - ); - if (rec.transactionId === id) { - t.record = rec; - if (transaction.oldRecord) { t.oldRecord = transaction.oldRecord; } - t.verified = true; - } else { - t.verified = false; - } - - return t; - }; - - const pickOne = async (trans, forType) => { - const transForType = filter(forType)(trans); - if (transForType.length === 1) { - const t = await verify(transForType[0]); - return (t.verified === true ? t : null); - } - for (let t of transForType) { - t = await verify(t); - if (t.verified === true) { return t; } - } - - return null; - }; - - for (const recordId in transactionIdsByRecord) { - const transIdsForRecord = transactionIdsByRecord[recordId]; - if (transIdsForRecord.length === 1) { - const t = await verify(transIdsForRecord[0]); - if (t.verified) { dedupedTransactions.push(t); } - continue; - } - if (some(isDelete)(transIdsForRecord)) { - const t = await verify(find(isDelete)(transIdsForRecord)); - if (t.verified) { dedupedTransactions.push(t); } - continue; - } - if (some(isUpdate)(transIdsForRecord)) { - const upd = await pickOne(transIdsForRecord, isUpdate); - if (isSomething(upd) && upd.verified) { dedupedTransactions.push(upd); } - continue; - } - if (some(isCreate)(transIdsForRecord)) { - const cre = await pickOne(transIdsForRecord, isCreate); - if (isSomething(cre)) { dedupedTransactions.push(cre); } - continue; - } - } - - const duplicates = $(transactionIds, [ - filter(t => none(ddt => ddt.uniqueId === t.uniqueId)(dedupedTransactions)), - ]); - - - const deletePromises = map(t => app.datastore.deleteFile( - joinKey( - TRANSACTIONS_FOLDER, - getTransactionId( - t.recordId, - t.transactionType, - t.uniqueId, - ), - ), - ))(duplicates); - - await Promise.all(deletePromises); - - return dedupedTransactions; -}; - -const parseTransactionId = (id) => { - const splitId = split(idSep)(id); - return ({ - recordId: splitId[0], - transactionType: splitId[1], - uniqueId: splitId[2], - fullId: id, - }); -}; - -const getRelevantAncestorIndexes = (hierarchy, record) => { - const key = record.key; - const keyParts = splitKey(key); - const nodeId = getRecordNodeId(key); - - const flatHierarchy = orderBy$1(getFlattenedHierarchy(hierarchy), - [node => node.pathRegx().length], - ['desc']); - - const makeindexNodeAndDir_ForAncestorIndex = (indexNode, parentRecordDir) => makeIndexNodeAndDir(indexNode, joinKey(parentRecordDir, indexNode.name)); - - const traverseAncestorIndexesInPath = () => reduce((acc, part) => { - const currentIndexKey = joinKey(acc.lastIndexKey, part); - acc.lastIndexKey = currentIndexKey; - const testPathRegx = p => new RegExp(`${p.pathRegx()}$`).test(currentIndexKey); - const nodeMatch = find(testPathRegx)(flatHierarchy); - - if (isNothing(nodeMatch)) { return acc; } - - if (!isRecord(nodeMatch) - || nodeMatch.indexes.length === 0) { return acc; } - - const indexes = $(nodeMatch.indexes, [ - filter(i => i.indexType === indexTypes.ancestor - && (i.allowedRecordNodeIds.length === 0 - || includes(nodeId)(i.allowedRecordNodeIds))), - ]); - - const currentRecordDir = getRecordInfo(hierarchy, currentIndexKey).dir; - - each(v => acc.nodesAndKeys.push( - makeindexNodeAndDir_ForAncestorIndex(v, currentRecordDir), - ))(indexes); - - return acc; - }, { lastIndexKey: '', nodesAndKeys: [] })(keyParts).nodesAndKeys; - - const rootIndexes = $(flatHierarchy, [ - filter(n => isGlobalIndex(n) && recordNodeIdIsAllowed(n)(nodeId)), - map(i => makeIndexNodeAndDir( - i, - getIndexDir(hierarchy, i.nodeKey()))), - ]); - - return union(traverseAncestorIndexesInPath())(rootIndexes); -}; - -const getRelevantReverseReferenceIndexes = (hierarchy, record) => $(record.key, [ - getExactNodeForKey(hierarchy), - n => n.fields, - filter(f => f.type === 'reference' - && isSomething(record[f.name]) - && isNonEmptyString(record[f.name].key)), - map(f => $(f.typeOptions.reverseIndexNodeKeys, [ - map(n => ({ - recordNode: getNode(hierarchy, n), - field: f, - })), - ])), - flatten, - map(n => makeIndexNodeAndDir( - n.recordNode, - joinKey( - getRecordInfo(hierarchy, record[n.field.name].key).dir, - n.recordNode.name), - )), -]); - -const makeIndexNodeAndDir = (indexNode, indexDir) => ({ indexNode, indexDir }); - -// adapted from https://github.com/dex4er/js-promise-writable - // Thank you :) - const promiseWriteableStream = stream => { - - let _errored; - - const _errorHandler = err => { - _errored = err; - }; - - stream.on("error", _errorHandler); - - const write = chunk => { - let rejected = false; - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err); - } - - if (!stream.writable || stream.closed || stream.destroyed) { - return reject(new Error("write after end")); - } - - const writeErrorHandler = err => { - _errored = undefined; - rejected = true; - reject(err); - }; - - stream.once("error", writeErrorHandler); - - const canWrite = stream.write(chunk); - - stream.removeListener("error", writeErrorHandler); - - if (canWrite) { - if (!rejected) { - resolve(chunk.length); - } - } else { - const errorHandler = err => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const drainHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const closeHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const finishHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const removeListeners = () => { - stream.removeListener("close", closeHandler); - stream.removeListener("drain", drainHandler); - stream.removeListener("error", errorHandler); - stream.removeListener("finish", finishHandler); - }; - - stream.on("close", closeHandler); - stream.on("drain", drainHandler); - stream.on("error", errorHandler); - stream.on("finish", finishHandler); - } - }) - }; - - const end = () => { - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err); - } - - if (!stream.writable || stream.closed || stream.destroyed) { - return resolve(); - } - - const finishHandler = () => { - removeListeners(); - resolve(); - }; - - const errorHandler = (err) => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const removeListeners = () => { - stream.removeListener("error", errorHandler); - stream.removeListener("finish", finishHandler); - }; - - stream.on("finish", finishHandler); - stream.on("error", errorHandler); - - stream.end(); - }) - }; - - return {write, end}; - }; - -const applyToShard = async (hierarchy, store, indexDir, - indexNode, indexShardKey, recordsToWrite, keysToRemove) => { - const createIfNotExists = recordsToWrite.length > 0; - const writer = await getWriter(hierarchy, store, indexDir, indexShardKey, indexNode, createIfNotExists); - if (writer === SHARD_DELETED) return; - - await writer.updateIndex(recordsToWrite, keysToRemove); - await swapTempFileIn(store, indexShardKey); -}; - -const SHARD_DELETED = 'SHARD_DELETED'; -const getWriter = async (hierarchy, store, indexDir, indexedDataKey, indexNode, createIfNotExists) => { - let readableStream = null; - - if (isShardedIndex(indexNode)) { - await ensureShardNameIsInShardMap(store, indexDir, indexedDataKey); - if(!await store.exists(indexedDataKey)) { - if (await store.exists(getParentKey(indexedDataKey))) { - await store.createFile(indexedDataKey, ""); - } else { - return SHARD_DELETED; - } - } - } - - try { - - readableStream = promiseReadableStream( - await store.readableFileStream(indexedDataKey) - ); - - } catch (e) { - - if (await store.exists(indexedDataKey)) { - throw e; - } else { - if (createIfNotExists) { - if(await store.exists(getParentKey(indexedDataKey))) { - await store.createFile(indexedDataKey, ''); - } else { - return SHARD_DELETED; - } - } else { - return SHARD_DELETED; - } - - readableStream = promiseReadableStream( - await store.readableFileStream(indexedDataKey) - ); - - } - } - - const writableStream = promiseWriteableStream( - await store.writableFileStream(indexedDataKey + ".temp") - ); - - return getIndexWriter( - hierarchy, indexNode, - readableStream, writableStream - ); -}; - -const swapTempFileIn = async (store, indexedDataKey, isRetry = false) => { - const tempFile = `${indexedDataKey}.temp`; - try { - await store.deleteFile(indexedDataKey); - } catch (e) { - // ignore failure, incase it has not been created yet - - // if parent folder does not exist, assume that this index - // should not be there - if(!await store.exists(getParentKey(indexedDataKey))) { - return; - } - } - try { - await store.renameFile(tempFile, indexedDataKey); - } catch (e) { - // retrying in case delete failure was for some other reason - if (!isRetry) { - await swapTempFileIn(store, indexedDataKey, true); - } else { - throw new Error("Failed to swap in index filed: " + e.message); - } - } -}; - -const executeTransactions = app => async (transactions) => { - const recordsByShard = mappedRecordsByIndexShard(app.hierarchy, transactions); - - for (const shard of keys(recordsByShard)) { - await applyToShard( - app.hierarchy, app.datastore, - recordsByShard[shard].indexDir, - recordsByShard[shard].indexNode, - shard, - recordsByShard[shard].writes, - recordsByShard[shard].removes, - ); - } -}; - -const mappedRecordsByIndexShard = (hierarchy, transactions) => { - const updates = getUpdateTransactionsByShard( - hierarchy, transactions, - ); - - const created = getCreateTransactionsByShard( - hierarchy, transactions, - ); - const deletes = getDeleteTransactionsByShard( - hierarchy, transactions, - ); - - const indexBuild = getBuildIndexTransactionsByShard( - hierarchy, - transactions, - ); - - const toRemove = [ - ...deletes, - ...updates.toRemove, - ]; - - const toWrite = [ - ...created, - ...updates.toWrite, - ...indexBuild, - ]; - - const transByShard = {}; - - const initialiseShard = (t) => { - if (isUndefined(transByShard[t.indexShardKey])) { - transByShard[t.indexShardKey] = { - writes: [], - removes: [], - indexDir: t.indexDir, - indexNodeKey: t.indexNode.nodeKey(), - indexNode: t.indexNode, - }; - } - }; - - for (const trans of toWrite) { - initialiseShard(trans); - transByShard[trans.indexShardKey].writes.push( - trans.mappedRecord.result, - ); - } - - for (const trans of toRemove) { - initialiseShard(trans); - transByShard[trans.indexShardKey].removes.push( - trans.mappedRecord.result.key, - ); - } - - return transByShard; -}; - -const getUpdateTransactionsByShard = (hierarchy, transactions) => { - const updateTransactions = $(transactions, [filter(isUpdate)]); - - const evaluateIndex = (record, indexNodeAndPath) => { - const mappedRecord = evaluate(record)(indexNodeAndPath.indexNode); - return ({ - mappedRecord, - indexNode: indexNodeAndPath.indexNode, - indexDir: indexNodeAndPath.indexDir, - indexShardKey: getIndexedDataKey( - indexNodeAndPath.indexNode, - indexNodeAndPath.indexDir, - mappedRecord.result, - ), - }); - }; - - const getIndexNodesToApply = indexFilter => (t, indexes) => $(indexes, [ - map(n => ({ - old: evaluateIndex(t.oldRecord, n), - new: evaluateIndex(t.record, n), - })), - filter(indexFilter), - ]); - - const toRemoveFilter = (n, isUnreferenced) => n.old.mappedRecord.passedFilter === true - && (n.new.mappedRecord.passedFilter === false - || isUnreferenced); - - const toAddFilter = (n, isNewlyReferenced) => (n.old.mappedRecord.passedFilter === false - || isNewlyReferenced) - && n.new.mappedRecord.passedFilter === true; - - const toUpdateFilter = n => n.new.mappedRecord.passedFilter === true - && n.old.mappedRecord.passedFilter === true - && !isEqual(n.old.mappedRecord.result, - n.new.mappedRecord.result); - - const toRemove = []; - const toWrite = []; - - for (const t of updateTransactions) { - const ancestorIdxs = getRelevantAncestorIndexes( - hierarchy, t.record, - ); - - const referenceChanges = diffReverseRefForUpdate( - hierarchy, t.oldRecord, t.record, - ); - - // old records to remove (filtered out) - const filteredOut_toRemove = union$1( - getIndexNodesToApply(toRemoveFilter)(t, ancestorIdxs), - // still referenced - check filter - getIndexNodesToApply(toRemoveFilter)(t, referenceChanges.notChanged), - // un referenced - remove if in there already - getIndexNodesToApply(n => toRemoveFilter(n, true))(t, referenceChanges.unReferenced), - ); - - // new records to add (filtered in) - const filteredIn_toAdd = union$1( - getIndexNodesToApply(toAddFilter)(t, ancestorIdxs), - // newly referenced - check filter - getIndexNodesToApply(n => toAddFilter(n, true))(t, referenceChanges.newlyReferenced), - // reference unchanged - rerun filter in case something else changed - getIndexNodesToApply(toAddFilter)(t, referenceChanges.notChanged), - ); - - const changed = union$1( - getIndexNodesToApply(toUpdateFilter)(t, ancestorIdxs), - // still referenced - recheck filter - getIndexNodesToApply(toUpdateFilter)(t, referenceChanges.notChanged), - ); - - const shardKeyChanged = $(changed, [ - filter(c => c.old.indexShardKey !== c.new.indexShardKey), - ]); - - const changedInSameShard = $(shardKeyChanged, [ - difference(changed), - ]); - - for (const res of shardKeyChanged) { - pull(res)(changed); - filteredOut_toRemove.push(res); - filteredIn_toAdd.push(res); - } - - toRemove.push( - $(filteredOut_toRemove, [ - map(i => i.old), - ]), - ); - - toWrite.push( - $(filteredIn_toAdd, [ - map(i => i.new), - ]), - ); - - toWrite.push( - $(changedInSameShard, [ - map(i => i.new), - ]), - ); - } - - return ({ - toRemove: flatten(toRemove), - toWrite: flatten(toWrite), - }); -}; - -const getBuildIndexTransactionsByShard = (hierarchy, transactions) => { - const buildTransactions = $(transactions, [filter(isBuildIndex)]); - if (!isNonEmptyArray(buildTransactions)) return []; - const indexNode = transactions.indexNode; - - const getIndexDirs = (t) => { - if (isGlobalIndex(indexNode)) { - return [indexNode.nodeKey()]; - } - - if (isReferenceIndex(indexNode)) { - const recordNode = getExactNodeForKey(hierarchy)(t.record.key); - const refFields = $(recordNode.fields, [ - filter(fieldReversesReferenceToIndex(indexNode)), - ]); - const indexDirs = []; - for (const refField of refFields) { - const refValue = t.record[refField.name]; - if (isSomething(refValue) - && isNonEmptyString(refValue.key)) { - const indexDir = joinKey( - getRecordInfo(hierarchy, refValue.key).dir, - indexNode.name, - ); - - if (!includes(indexDir)(indexDirs)) { indexDirs.push(indexDir); } - } - } - return indexDirs; - } - - const indexKey = joinKey( - getActualKeyOfParent( - indexNode.parent().nodeKey(), - t.record.key, - ), - indexNode.name, - ); - - return [getIndexDir(hierarchy, indexKey)]; - }; - - return $(buildTransactions, [ - map((t) => { - const mappedRecord = evaluate(t.record)(indexNode); - if (!mappedRecord.passedFilter) return null; - const indexDirs = getIndexDirs(t); - return $(indexDirs, [ - map(indexDir => ({ - mappedRecord, - indexNode, - indexDir, - indexShardKey: getIndexedDataKey( - indexNode, - indexDir, - mappedRecord.result, - ), - })), - ]); - }), - flatten, - filter(isSomething), - ]); -}; - -const get_Create_Delete_TransactionsByShard = pred => (hierarchy, transactions) => { - const createTransactions = $(transactions, [filter(pred)]); - - const getIndexNodesToApply = (t, indexes) => $(indexes, [ - map((n) => { - const mappedRecord = evaluate(t.record)(n.indexNode); - return ({ - mappedRecord, - indexNode: n.indexNode, - indexDir: n.indexDir, - indexShardKey: getIndexedDataKey( - n.indexNode, - n.indexDir, - mappedRecord.result, - ), - }); - }), - filter(n => n.mappedRecord.passedFilter), - ]); - - const allToApply = []; - - for (const t of createTransactions) { - const ancestorIdxs = getRelevantAncestorIndexes(hierarchy, t.record); - const reverseRef = getRelevantReverseReferenceIndexes(hierarchy, t.record); - - allToApply.push( - getIndexNodesToApply(t, ancestorIdxs), - ); - allToApply.push( - getIndexNodesToApply(t, reverseRef), - ); - } - - return flatten(allToApply); -}; - -const getDeleteTransactionsByShard = get_Create_Delete_TransactionsByShard(isDelete); - -const getCreateTransactionsByShard = get_Create_Delete_TransactionsByShard(isCreate); - -const diffReverseRefForUpdate = (appHierarchy, oldRecord, newRecord) => { - const oldIndexes = getRelevantReverseReferenceIndexes( - appHierarchy, oldRecord, - ); - const newIndexes = getRelevantReverseReferenceIndexes( - appHierarchy, newRecord, - ); - - const unReferenced = differenceBy( - i => i.indexDir, - oldIndexes, newIndexes, - ); - - const newlyReferenced = differenceBy( - i => i.indexDir, - newIndexes, oldIndexes, - ); - - const notChanged = intersectionBy( - i => i.indexDir, - newIndexes, oldIndexes, - ); - - return { - unReferenced, - newlyReferenced, - notChanged, - }; -}; - -const cleanup = async (app) => { - const lock = await getTransactionLock(app); - if (isNolock(lock)) return; - - try { - const transactions = await retrieve(app); - if (transactions.length > 0) { - await executeTransactions(app)(transactions); - - const folder = transactions.folderKey - ? transactions.folderKey - : TRANSACTIONS_FOLDER; - - const deleteFiles = $(transactions, [ - map(t => joinKey( - folder, - getTransactionId( - t.recordId, t.transactionType, - t.uniqueId, - ), - )), - map(app.datastore.deleteFile), - ]); - - await Promise.all(deleteFiles); - } - } finally { - await releaseLock(app, lock); - } -}; - -const getTransactionLock = async app => await getLock( - app, LOCK_FILE_KEY, - timeoutMilliseconds, maxLockRetries, -); - -const initialiseData = async (datastore, applicationDefinition, accessLevels) => { - await datastore.createFolder(configFolder); - await datastore.createJson(appDefinitionFile, applicationDefinition); - - await initialiseRootCollections(datastore, applicationDefinition.hierarchy); - await initialiseRootIndexes(datastore, applicationDefinition.hierarchy); - - await datastore.createFolder(TRANSACTIONS_FOLDER); - - await datastore.createFolder(AUTH_FOLDER); - - await datastore.createJson(USERS_LIST_FILE, []); - - await datastore.createJson( - ACCESS_LEVELS_FILE, - accessLevels ? accessLevels : { version: 0, levels: [] }); - - await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy); -}; - -const initialiseRootIndexes = async (datastore, hierarchy) => { - const flathierarchy = getFlattenedHierarchy(hierarchy); - const globalIndexes = $(flathierarchy, [ - filter(isGlobalIndex), - ]); - - for (const index of globalIndexes) { - if (!await datastore.exists(index.nodeKey())) { - await initialiseIndex(datastore, '', index); - } - } -}; - -const initialiseRootSingleRecords = async (datastore, hierarchy) => { - const app = { - publish:()=>{}, - cleanupTransactions: () => {}, - datastore, hierarchy - }; - - const flathierarchy = getFlattenedHierarchy(hierarchy); - const singleRecords = $(flathierarchy, [ - filter(isSingleRecord), - ]); - - for (let record of singleRecords) { - await datastore.createFolder(record.nodeKey()); - const result = _getNew(record, ""); - await _save(app,result); - } -}; - -const getDatabaseManager = databaseManager => ({ - createEmptyMasterDb: createEmptyMasterDb(databaseManager), - createEmptyInstanceDb: createEmptyInstanceDb(databaseManager), - getInstanceDbRootConfig: databaseManager.getInstanceDbRootConfig, - masterDatastoreConfig: getMasterDatastoreConfig(databaseManager), - getInstanceDatastoreConfig: getInstanceDatastoreConfig(databaseManager), -}); - -const getMasterDatastoreConfig = databaseManager => databaseManager.getDatastoreConfig('master'); - -const getInstanceDatastoreConfig = databaseManager => (applicationId, instanceId) => databaseManager.getDatastoreConfig( - applicationId, instanceId, -); - -const createEmptyMasterDb = databaseManager => async () => await databaseManager.createEmptyDb('master'); - -const createEmptyInstanceDb = databaseManager => async (applicationId, instanceId) => { - if (isNothing(applicationId)) { throw new Error('CreateDb: application id not supplied'); } - if (isNothing(instanceId)) { throw new Error('CreateDb: instance id not supplied'); } - - return await databaseManager.createEmptyDb( - applicationId, - instanceId, - ); -}; - -const getAppApis = async (store, behaviourSources = null, - cleanupTransactions = null, - getEpochTime = null, - crypto = null, - appDefinition = null) => { - - store = setupDatastore(store); - - if(!appDefinition) - appDefinition = await getApplicationDefinition(store)(); - - if(!behaviourSources) - behaviourSources = await getBehaviourSources(store); - - const eventAggregator = createEventAggregator(); - - const app = { - datastore:store, - crypto, - publish:eventAggregator.publish, - hierarchy:appDefinition.hierarchy, - actions:appDefinition.actions - }; - - const templateApi = getTemplateApi(app); - - app.cleanupTransactions = isSomething(cleanupTransactions) - ? cleanupTransactions - : async () => await cleanup(app); - - app.getEpochTime = isSomething(getEpochTime) - ? getEpochTime - : async () => (new Date()).getTime(); - - const recordApi = getRecordApi(app); - const collectionApi = getCollectionApi(app); - const indexApi = getIndexApi(app); - const authApi = getAuthApi(app); - const actionsApi = getActionsApi(app); - - const authenticateAs = async (username, password) => { - app.user = await authApi.authenticate(username, password); - }; - - const withFullAccess = () => - userWithFullAccess(app); - - const asUser = (user) => { - app.user = user; - }; - - let apis = { - recordApi, - templateApi, - collectionApi, - indexApi, - authApi, - actionsApi, - subscribe: eventAggregator.subscribe, - authenticateAs, - withFullAccess, - asUser - }; - - apis.actions = initialiseActions( - eventAggregator.subscribe, - behaviourSources, - appDefinition.actions, - appDefinition.triggers, - apis); - - - return apis; -}; - -const userWithFullAccess = (app) => { - app.user = { - name: "app", - permissions : generateFullPermissions(app), - isUser:false, - temp:false - }; - return app.user; -}; - -export default getAppApis; -export { index as common, events, eventsList, getActionsApi, getAppApis, getAuthApi, getCollectionApi, getDatabaseManager, getIndexApi, getRecordApi, getTemplateApi, hierarchy, initialiseData, setupDatastore, userWithFullAccess }; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"budibase-core.esm.mjs","sources":["../src/common/events.js","../src/common/errors.js","../src/common/apiWrapper.js","../src/common/lock.js","../src/common/index.js","../src/common/validationCommon.js","../src/indexing/evaluate.js","../src/templateApi/indexes.js","../src/templateApi/hierarchy.js","../src/types/typeHelpers.js","../src/types/string.js","../src/types/bool.js","../src/types/number.js","../src/types/datetime.js","../src/types/array.js","../src/types/reference.js","../src/types/file.js","../src/types/index.js","../src/authApi/authCommon.js","../src/authApi/isAuthorized.js","../src/authApi/permissions.js","../src/recordApi/getNew.js","../src/indexing/allIds.js","../src/recordApi/recordInfo.js","../src/recordApi/load.js","../src/indexing/promiseReadableStream.js","../src/indexing/sharding.js","../src/indexing/indexSchemaCreator.js","../node_modules/rollup-plugin-node-globals/src/global.js","../node_modules/buffer-es6/base64.js","../node_modules/buffer-es6/ieee754.js","../node_modules/buffer-es6/isArray.js","../node_modules/buffer-es6/index.js","../node_modules/rollup-plugin-node-builtins/src/es6/string-decoder.js","../src/indexing/serializer.js","../src/indexing/read.js","../src/indexApi/getIndexDir.js","../src/indexApi/listItems.js","../src/recordApi/getContext.js","../src/recordApi/validate.js","../src/collectionApi/initialise.js","../src/transactions/transactionsCommon.js","../src/transactions/create.js","../src/indexing/initialiseIndex.js","../src/recordApi/save.js","../src/collectionApi/delete.js","../src/recordApi/delete.js","../src/recordApi/uploadFile.js","../src/recordApi/downloadFile.js","../src/recordApi/customId.js","../src/recordApi/index.js","../src/collectionApi/getAllowedRecordTypes.js","../src/collectionApi/index.js","../src/indexApi/buildIndex.js","../src/indexApi/aggregates.js","../src/indexApi/index.js","../src/templateApi/createNodes.js","../src/templateApi/fields.js","../src/templateApi/recordValidationRules.js","../src/templateApi/createActions.js","../src/templateApi/validateAggregate.js","../src/templateApi/validate.js","../src/templateApi/getApplicationDefinition.js","../src/templateApi/saveApplicationHierarchy.js","../src/templateApi/saveActionsAndTriggers.js","../src/templateApi/getBehaviourSources.js","../src/templateApi/index.js","../src/authApi/getUsers.js","../src/authApi/loadAccessLevels.js","../src/authApi/authenticate.js","../src/authApi/createTemporaryAccess.js","../src/authApi/validateUser.js","../src/authApi/getNewUser.js","../src/authApi/setPassword.js","../src/authApi/createUser.js","../src/authApi/enableUser.js","../src/authApi/getNewAccessLevel.js","../src/authApi/validateAccessLevels.js","../src/authApi/saveAccessLevels.js","../src/authApi/generateFullPermissions.js","../src/authApi/setUserAccessLevels.js","../src/authApi/index.js","../src/actionsApi/execute.js","../src/actionsApi/index.js","../src/appInitialise/eventAggregator.js","../src/appInitialise/index.js","../src/common/compileCode.js","../src/actionsApi/initialise.js","../src/transactions/retrieve.js","../src/indexing/relevant.js","../src/indexing/promiseWritableStream.js","../src/indexing/apply.js","../src/transactions/execute.js","../src/transactions/cleanup.js","../src/appInitialise/initialiseData.js","../src/appInitialise/databaseManager.js","../src/index.js"],"sourcesContent":["import { union, reduce } from 'lodash/fp';\n\nconst commonPlus = extra => union(['onBegin', 'onComplete', 'onError'])(extra);\n\nconst common = () => commonPlus([]);\n\nconst _events = {\n  recordApi: {\n    save: commonPlus([\n      'onInvalid',\n      'onRecordUpdated',\n      'onRecordCreated']),\n    delete: common(),\n    getContext: common(),\n    getNew: common(),\n    load: common(),\n    validate: common(),\n    uploadFile: common(),\n    downloadFile: common(),\n  },\n  indexApi: {\n    buildIndex: common(),\n    listItems: common(),\n    delete: common(),\n    aggregates: common(),\n  },\n  collectionApi: {\n    getAllowedRecordTypes: common(),\n    initialise: common(),\n    delete: common(),\n  },\n  authApi: {\n    authenticate: common(),\n    authenticateTemporaryAccess: common(),\n    createTemporaryAccess: common(),\n    createUser: common(),\n    enableUser: common(),\n    disableUser: common(),\n    loadAccessLevels: common(),\n    getNewAccessLevel: common(),\n    getNewUser: common(),\n    getNewUserAuth: common(),\n    getUsers: common(),\n    saveAccessLevels: common(),\n    isAuthorized: common(),\n    changeMyPassword: common(),\n    setPasswordFromTemporaryCode: common(),\n    scorePassword: common(),\n    isValidPassword: common(),\n    validateUser: common(),\n    validateAccessLevels: common(),\n    setUserAccessLevels: common(),\n  },\n  templateApi: {\n    saveApplicationHierarchy: common(),\n    saveActionsAndTriggers: common(),\n  },\n  actionsApi: {\n    execute: common(),\n  },\n};\n\nconst _eventsList = [];\n\nconst makeEvent = (area, method, name) => `${area}:${method}:${name}`;\n\nfor (const areaKey in _events) {\n  for (const methodKey in _events[areaKey]) {\n    _events[areaKey][methodKey] = reduce((obj, s) => {\n      obj[s] = makeEvent(areaKey, methodKey, s);\n      return obj;\n    },\n    {})(_events[areaKey][methodKey]);\n  }\n}\n\n\nfor (const areaKey in _events) {\n  for (const methodKey in _events[areaKey]) {\n    for (const name in _events[areaKey][methodKey]) {\n      _eventsList.push(\n        _events[areaKey][methodKey][name],\n      );\n    }\n  }\n}\n\n\nexport const events = _events;\n\nexport const eventsList = _eventsList;\n\nexport default { events: _events, eventsList: _eventsList };\n","export class BadRequestError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 400;\n    }\n}\n\nexport class UnauthorisedError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 401;\n    }\n}\n\nexport class ForbiddenError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 403;\n    }\n}\n\nexport class NotFoundError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 404;\n    }\n}\n\nexport class ConflictError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 409;\n    }\n}","import { cloneDeep, isUndefined } from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { UnauthorisedError } from './errors';\n\nexport const apiWrapper = async (app, eventNamespace, isAuthorized, eventContext, func, ...params) => {\n  pushCallStack(app, eventNamespace);\n\n  if (!isAuthorized(app)) {\n    handleNotAuthorized(app, eventContext, eventNamespace);\n    return;\n  }\n\n  const startDate = Date.now();\n  const elapsed = () => (Date.now() - startDate);\n\n  try {\n    await app.publish(\n      eventNamespace.onBegin,\n      eventContext,\n    );\n\n    const result = await func(...params);\n\n    await publishComplete(app, eventContext, eventNamespace, elapsed, result);\n    return result;\n  } catch (error) {\n    await publishError(app, eventContext, eventNamespace, elapsed, error);\n    throw error;\n  }\n};\n\nexport const apiWrapperSync = (app, eventNamespace, isAuthorized, eventContext, func, ...params) => {\n  pushCallStack(app, eventNamespace);\n\n  if (!isAuthorized(app)) {\n    handleNotAuthorized(app, eventContext, eventNamespace);\n    return;\n  }\n\n  const startDate = Date.now();\n  const elapsed = () => (Date.now() - startDate);\n\n  try {\n    app.publish(\n      eventNamespace.onBegin,\n      eventContext,\n    );\n\n    const result = func(...params);\n\n    publishComplete(app, eventContext, eventNamespace, elapsed, result);\n    return result;\n  } catch (error) {\n    publishError(app, eventContext, eventNamespace, elapsed, error);\n    throw error;\n  }\n};\n\nconst handleNotAuthorized = (app, eventContext, eventNamespace) => {\n  const err = new UnauthorisedError(`Unauthorized: ${eventNamespace}`);\n  publishError(app, eventContext, eventNamespace, () => 0, err);\n  throw err;\n};\n\nconst pushCallStack = (app, eventNamespace, seedCallId) => {\n  const callId = generate();\n\n  const createCallStack = () => ({\n    seedCallId: !isUndefined(seedCallId)\n      ? seedCallId\n      : callId,\n    threadCallId: callId,\n    stack: [],\n  });\n\n  if (isUndefined(app.calls)) {\n    app.calls = createCallStack();\n  }\n\n  app.calls.stack.push({\n    namespace: eventNamespace,\n    callId,\n  });\n};\n\nconst popCallStack = (app) => {\n  app.calls.stack.pop();\n  if (app.calls.stack.length === 0) {\n    delete app.calls;\n  }\n};\n\nconst publishError = async (app, eventContext, eventNamespace, elapsed, err) => {\n  const ctx = cloneDeep(eventContext);\n  ctx.error = err;\n  ctx.elapsed = elapsed();\n  await app.publish(\n    eventNamespace.onError,\n    ctx,\n  );\n  popCallStack(app);\n};\n\nconst publishComplete = async (app, eventContext, eventNamespace, elapsed, result) => {\n  const endcontext = cloneDeep(eventContext);\n  endcontext.result = result;\n  endcontext.elapsed = elapsed();\n  await app.publish(\n    eventNamespace.onComplete,\n    endcontext,\n  );\n  popCallStack(app);\n  return result;\n};\n\nexport default apiWrapper;\n","import { split } from 'lodash/fp';\nimport { $ } from './index';\n\nconst lockOverlapMilliseconds = 10;\n\nexport const getLock = async (app, lockFile, timeoutMilliseconds, maxLockRetries, retryCount = 0) => {\n  try {\n    const timeout = (await app.getEpochTime())\n            + timeoutMilliseconds;\n\n    const lock = {\n      timeout,\n      key: lockFile,\n      totalTimeout: timeoutMilliseconds,\n    };\n\n    await app.datastore.createFile(\n      lockFile,\n      getLockFileContent(\n        lock.totalTimeout,\n        lock.timeout,\n      ),\n    );\n\n    return lock;\n  } catch (e) {\n    if (retryCount == maxLockRetries) { return NO_LOCK; }\n\n    const lock = parseLockFileContent(\n      lockFile,\n      await app.datastore.loadFile(lockFile),\n    );\n\n    const currentEpochTime = await app.getEpochTime();\n\n    if (currentEpochTime < lock.timeout) {\n      return NO_LOCK;\n    }\n\n    try {\n      await app.datastore.deleteFile(lockFile);\n    } catch (_) {\n      //empty\n    }\n\n    await sleepForRetry();\n\n    return await getLock(\n      app, lockFile, timeoutMilliseconds,\n      maxLockRetries, retryCount + 1,\n    );\n  }\n};\n\nexport const getLockFileContent = (totalTimeout, epochTime) => `${totalTimeout}:${epochTime.toString()}`;\n\nconst parseLockFileContent = (key, content) => $(content, [\n  split(':'),\n  parts => ({\n    totalTimeout: new Number(parts[0]),\n    timeout: new Number(parts[1]),\n    key,\n  }),\n]);\n\nexport const releaseLock = async (app, lock) => {\n  const currentEpochTime = await app.getEpochTime();\n  // only release if not timedout\n  if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) {\n    try {\n      await app.datastore.deleteFile(lock.key);\n    } catch (_) {\n      //empty\n    }\n  }\n};\n\nexport const extendLock = async (app, lock) => {\n  const currentEpochTime = await app.getEpochTime();\n  // only release if not timedout\n  if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) {\n    try {\n      lock.timeout = currentEpochTime + lock.timeoutMilliseconds;\n      await app.datastore.updateFile(\n        lock.key,\n        getLockFileContent(lock.totalTimeout, lock.timeout),\n      );\n      return lock;\n    } catch (_) {\n      //empty\n    }\n  }\n  return NO_LOCK;\n};\n\nexport const NO_LOCK = 'no lock';\nexport const isNolock = id => id === NO_LOCK;\n\nconst sleepForRetry = () => new Promise(resolve => setTimeout(resolve, lockOverlapMilliseconds));\n","import {\n  \n  head, \n  tail, findIndex, startsWith, \n  dropRight, flow, takeRight, trim,\n  replace\n} from 'lodash';\nimport { \n  some, reduce, isEmpty, isArray, join,\n  isString, isInteger, isDate, toNumber,\n  isUndefined, isNaN, isNull, constant,\n  split, includes, filter\n} from 'lodash/fp';\nimport { events, eventsList } from './events';\nimport { apiWrapper } from './apiWrapper';\nimport {\n  getLock, NO_LOCK,\n  isNolock\n} from './lock';\n\n// this is the combinator function\nexport const $$ = (...funcs) => arg => flow(funcs)(arg);\n\n// this is the pipe function\nexport const $ = (arg, funcs) => $$(...funcs)(arg);\n\nexport const keySep = '/';\nconst trimKeySep = str => trim(str, keySep);\nconst splitByKeySep = str => split(keySep)(str);\nexport const safeKey = key => replace(`${keySep}${trimKeySep(key)}`, `${keySep}${keySep}`, keySep);\nexport const joinKey = (...strs) => {\n  const paramsOrArray = strs.length === 1 & isArray(strs[0])\n    ? strs[0] : strs;\n  return $(paramsOrArray, [\n    filter(s => !isUndefined(s) \n                && !isNull(s) \n                && s.toString().length > 0),\n    join(keySep),\n    safeKey\n  ]);\n};\nexport const splitKey = $$(trimKeySep, splitByKeySep);\nexport const getDirFomKey = $$(splitKey, dropRight, p => joinKey(...p));\nexport const getFileFromKey = $$(splitKey, takeRight, head);\n\nexport const configFolder = `${keySep}.config`;\nexport const fieldDefinitions = joinKey(configFolder, 'fields.json');\nexport const templateDefinitions = joinKey(configFolder, 'templates.json');\nexport const appDefinitionFile = joinKey(configFolder, 'appDefinition.json');\nexport const dirIndex = folderPath => joinKey(configFolder, 'dir', ...splitKey(folderPath), 'dir.idx');\nexport const getIndexKeyFromFileKey = $$(getDirFomKey, dirIndex);\n\nexport const ifExists = (val, exists, notExists) => (isUndefined(val)\n  ? isUndefined(notExists) ? (() => { })() : notExists()\n  : exists());\n\nexport const getOrDefault = (val, defaultVal) => ifExists(val, () => val, () => defaultVal);\n\nexport const not = func => val => !func(val);\nexport const isDefined = not(isUndefined);\nexport const isNonNull = not(isNull);\nexport const isNotNaN = not(isNaN);\n\nexport const allTrue = (...funcArgs) => val => reduce(\n  (result, conditionFunc) => (isNull(result) || result == true) && conditionFunc(val),\n  null)(funcArgs);\n\nexport const anyTrue = (...funcArgs) => val => reduce(\n  (result, conditionFunc) => result == true || conditionFunc(val),\n  null)(funcArgs);\n\nexport const insensitiveEquals = (str1, str2) => str1.trim().toLowerCase() === str2.trim().toLowerCase();\n\nexport const isSomething = allTrue(isDefined, isNonNull, isNotNaN);\nexport const isNothing = not(isSomething);\nexport const isNothingOrEmpty = v => isNothing(v) || isEmpty(v);\nexport const somethingOrGetDefault = getDefaultFunc => val => (isSomething(val) ? val : getDefaultFunc());\nexport const somethingOrDefault = (val, defaultVal) => somethingOrGetDefault(constant(defaultVal))(val);\n\nexport const mapIfSomethingOrDefault = (mapFunc, defaultVal) => val => (isSomething(val) ? mapFunc(val) : defaultVal);\n\nexport const mapIfSomethingOrBlank = mapFunc => mapIfSomethingOrDefault(mapFunc, '');\n\nexport const none = predicate => collection => !some(predicate)(collection);\n\nexport const all = predicate => collection => none(v => !predicate(v))(collection);\n\nexport const isNotEmpty = ob => !isEmpty(ob);\nexport const isAsync = fn => fn.constructor.name === 'AsyncFunction';\nexport const isNonEmptyArray = allTrue(isArray, isNotEmpty);\nexport const isNonEmptyString = allTrue(isString, isNotEmpty);\nexport const tryOr = failFunc => (func, ...args) => {\n  try {\n    return func.apply(null, ...args);\n  } catch (_) {\n    return failFunc();\n  }\n};\n\nexport const tryAwaitOr = failFunc => async (func, ...args) => {\n  try {\n    return await func.apply(null, ...args);\n  } catch (_) {\n    return await failFunc();\n  }\n};\n\nexport const defineError = (func, errorPrefix) => {\n  try {\n    return func();\n  } catch (err) {\n    err.message = `${errorPrefix} : ${err.message}`;\n    throw err;\n  }\n};\n\nexport const tryOrIgnore = tryOr(() => { });\nexport const tryAwaitOrIgnore = tryAwaitOr(async () => { });\nexport const causesException = (func) => {\n  try {\n    func();\n    return false;\n  } catch (e) {\n    return true;\n  }\n};\n\nexport const executesWithoutException = func => !causesException(func);\n\nexport const handleErrorWith = returnValInError => tryOr(constant(returnValInError));\n\nexport const handleErrorWithUndefined = handleErrorWith(undefined);\n\nexport const switchCase = (...cases) => (value) => {\n  const nextCase = () => head(cases)[0](value);\n  const nextResult = () => head(cases)[1](value);\n\n  if (isEmpty(cases)) return; // undefined\n  if (nextCase() === true) return nextResult();\n  return switchCase(...tail(cases))(value);\n};\n\nexport const isValue = val1 => val2 => (val1 === val2);\nexport const isOneOf = (...vals) => val => includes(val)(vals);\nexport const defaultCase = constant(true);\nexport const memberMatches = (member, match) => obj => match(obj[member]);\n\n\nexport const StartsWith = searchFor => searchIn => startsWith(searchIn, searchFor);\n\nexport const contains = val => array => (findIndex(array, v => v === val) > -1);\n\nexport const getHashCode = (s) => {\n  let hash = 0; let i; let char; let\n    l;\n  if (s.length == 0) return hash;\n  for (i = 0, l = s.length; i < l; i++) {\n    char = s.charCodeAt(i);\n    hash = ((hash << 5) - hash) + char;\n    hash |= 0; // Convert to 32bit integer\n  }\n\n  // converting to string, but dont want a \"-\" prefixed\n  if (hash < 0) { return `n${(hash * -1).toString()}`; }\n  return hash.toString();\n};\n\n// thanks to https://blog.grossman.io/how-to-write-async-await-without-try-catch-blocks-in-javascript/\nexport const awEx = async (promise) => {\n  try {\n    const result = await promise;\n    return [undefined, result];\n  } catch (error) {\n    return [error, undefined];\n  }\n};\n\nexport const isSafeInteger = n => isInteger(n)\n    && n <= Number.MAX_SAFE_INTEGER\n    && n >= 0 - Number.MAX_SAFE_INTEGER;\n\nexport const toDateOrNull = s => (isNull(s) ? null\n  : isDate(s) ? s : new Date(s));\nexport const toBoolOrNull = s => (isNull(s) ? null\n  : s === 'true' || s === true);\nexport const toNumberOrNull = s => (isNull(s) ? null\n  : toNumber(s));\n\nexport const isArrayOfString = opts => isArray(opts) && all(isString)(opts);\n\nexport const pushAll = (target, items) => {\n  for(let i of items) target.push(i);\n}\n\nexport const pause = async duration => new Promise(res => setTimeout(res, duration));\n\nexport const retry = async (fn, retries, delay, ...args) => {\n  try {\n    return await fn(...args);\n  } catch (err) {\n    if (retries > 1) {\n      return await pause(delay).then(async () => await retry(fn, (retries - 1), delay, ...args));\n    }\n    throw err;\n  }\n};\n\nexport { events } from './events';\nexport { apiWrapper, apiWrapperSync } from './apiWrapper';\nexport {\n  getLock, NO_LOCK, releaseLock,\n  extendLock, isNolock,\n} from './lock';\n\nexport default {\n  ifExists,\n  getOrDefault,\n  isDefined,\n  isNonNull,\n  isNotNaN,\n  allTrue,\n  isSomething,\n  mapIfSomethingOrDefault,\n  mapIfSomethingOrBlank,\n  configFolder,\n  fieldDefinitions,\n  isNothing,\n  not,\n  switchCase,\n  defaultCase,\n  StartsWith,\n  contains,\n  templateDefinitions,\n  handleErrorWith,\n  handleErrorWithUndefined,\n  tryOr,\n  tryOrIgnore,\n  tryAwaitOr,\n  tryAwaitOrIgnore,\n  dirIndex,\n  keySep,\n  $,\n  $$,\n  getDirFomKey,\n  getFileFromKey,\n  splitKey,\n  somethingOrDefault,\n  getIndexKeyFromFileKey,\n  joinKey,\n  somethingOrGetDefault,\n  appDefinitionFile,\n  isValue,\n  all,\n  isOneOf,\n  memberMatches,\n  defineError,\n  anyTrue,\n  isNonEmptyArray,\n  causesException,\n  executesWithoutException,\n  none,\n  getHashCode,\n  awEx,\n  apiWrapper,\n  events,\n  eventsList,\n  isNothingOrEmpty,\n  isSafeInteger,\n  toNumber,\n  toDate: toDateOrNull,\n  toBool: toBoolOrNull,\n  isArrayOfString,\n  getLock,\n  NO_LOCK,\n  isNolock,\n  insensitiveEquals,\n  pause,\n  retry,\n  pushAll\n};\n","import { filter, map } from 'lodash/fp';\nimport { $, isSomething } from './index';\n\nexport const stringNotEmpty = s => isSomething(s) && s.trim().length > 0;\n\nexport const makerule = (field, error, isValid) => ({ field, error, isValid });\n\nexport const validationError = (rule, item) => ({ ...rule, item });\n\nexport const applyRuleSet = ruleSet => itemToValidate => $(ruleSet, [\n  map(applyRule(itemToValidate)),\n  filter(isSomething),\n]);\n\nexport const applyRule = itemTovalidate => rule => (rule.isValid(itemTovalidate)\n  ? null\n  : validationError(rule, itemTovalidate));\n","import { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  isUndefined, keys, \n  cloneDeep, isFunction,\n} from 'lodash/fp';\nimport { defineError } from '../common';\n\nexport const filterEval = 'FILTER_EVALUATE';\nexport const filterCompile = 'FILTER_COMPILE';\nexport const mapEval = 'MAP_EVALUATE';\nexport const mapCompile = 'MAP_COMPILE';\nexport const removeUndeclaredFields = 'REMOVE_UNDECLARED_FIELDS';\nexport const addUnMappedFields = 'ADD_UNMAPPED_FIELDS';\nexport const addTheKey = 'ADD_KEY';\n\n\nconst getEvaluateResult = () => ({\n  isError: false,\n  passedFilter: true,\n  result: null,\n});\n\nexport const compileFilter = index => compileExpression(index.filter);\n\nexport const compileMap = index => compileCode(index.map);\n\nexport const passesFilter = (record, index) => {\n  const context = { record };\n  if (!index.filter) return true;\n\n  const compiledFilter = defineError(\n    () => compileFilter(index),\n    filterCompile,\n  );\n\n  return defineError(\n    () => compiledFilter(context),\n    filterEval,\n  );\n};\n\nexport const mapRecord = (record, index) => {\n  const recordClone = cloneDeep(record);\n  const context = { record: recordClone };\n\n  const map = index.map ? index.map : 'return {...record};';\n\n  const compiledMap = defineError(\n    () => compileCode(map),\n    mapCompile,\n  );\n\n  const mapped = defineError(\n    () => compiledMap(context),\n    mapEval,\n  );\n\n  const mappedKeys = keys(mapped);\n  for (let i = 0; i < mappedKeys.length; i++) {\n    const key = mappedKeys[i];\n    mapped[key] = isUndefined(mapped[key]) ? null : mapped[key];\n    if (isFunction(mapped[key])) {\n      delete mapped[key];\n    }\n  }\n\n  mapped.key = record.key;\n  mapped.sortKey = index.getSortKey\n    ? compileCode(index.getSortKey)(context)\n    : record.id;\n\n  return mapped;\n};\n\nexport const evaluate = record => (index) => {\n  const result = getEvaluateResult();\n\n  try {\n    result.passedFilter = passesFilter(record, index);\n  } catch (err) {\n    result.isError = true;\n    result.passedFilter = false;\n    result.result = err.message;\n  }\n\n  if (!result.passedFilter) return result;\n\n  try {\n    result.result = mapRecord(record, index);\n  } catch (err) {\n    result.isError = true;\n    result.result = err.message;\n  }\n\n  return result;\n};\n\nexport default evaluate;\n","import {\n  map, isEmpty, countBy, \n  flatten, includes, join, keys\n} from 'lodash/fp';\nimport {  } from 'lodash';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { compileFilter, compileMap } from '../indexing/evaluate';\nimport { isNonEmptyString, executesWithoutException, $ } from '../common';\nimport { isRecord } from './hierarchy';\n\nexport const indexTypes = { reference: 'reference', ancestor: 'ancestor' };\n\nexport const indexRuleSet = [\n  makerule('map', 'index has no map function',\n    index => isNonEmptyString(index.map)),\n  makerule('map', \"index's map function does not compile\",\n    index => !isNonEmptyString(index.map)\n                || executesWithoutException(() => compileMap(index))),\n  makerule('filter', \"index's filter function does not compile\",\n    index => !isNonEmptyString(index.filter)\n                || executesWithoutException(() => compileFilter(index))),\n  makerule('name', 'must declare a name for index',\n    index => isNonEmptyString(index.name)),\n  makerule('name', 'there is a duplicate named index on this node',\n    index => isEmpty(index.name)\n                || countBy('name')(index.parent().indexes)[index.name] === 1),\n  makerule('indexType', 'reference index may only exist on a record node',\n    index => isRecord(index.parent())\n                  || index.indexType !== indexTypes.reference),\n  makerule('indexType', `index type must be one of: ${join(', ')(keys(indexTypes))}`,\n    index => includes(index.indexType)(keys(indexTypes))),\n];\n\nexport const validateIndex = (index, allReferenceIndexesOnNode) => applyRuleSet(indexRuleSet(allReferenceIndexesOnNode))(index);\n\nexport const validateAllIndexes = node => $(node.indexes, [\n  map(i => validateIndex(i, node.indexes)),\n  flatten,\n]);\n","import {\n  find, constant, map, last,\n  first, split, intersection, take,\n  union, includes, filter, some,\n} from 'lodash/fp';\nimport {\n  $, switchCase, isNothing, isSomething,\n  defaultCase, splitKey, isNonEmptyString,\n  joinKey, getHashCode,\n} from '../common';\nimport { indexTypes } from './indexes';\n\nexport const getFlattenedHierarchy = (appHierarchy, useCached = true) => {\n  if (isSomething(appHierarchy.getFlattenedHierarchy) && useCached) { return appHierarchy.getFlattenedHierarchy(); }\n\n  const flattenHierarchy = (currentNode, flattened) => {\n    flattened.push(currentNode);\n    if ((!currentNode.children\n            || currentNode.children.length === 0)\n            && (!currentNode.indexes\n            || currentNode.indexes.length === 0)\n            && (!currentNode.aggregateGroups\n            || currentNode.aggregateGroups.length === 0)) {\n      return flattened;\n    }\n\n    const unionIfAny = l2 => l1 => union(l1)(!l2 ? [] : l2);\n\n    const children = $([], [\n      unionIfAny(currentNode.children),\n      unionIfAny(currentNode.indexes),\n      unionIfAny(currentNode.aggregateGroups),\n    ]);\n\n    for (const child of children) {\n      flattenHierarchy(child, flattened);\n    }\n    return flattened;\n  };\n\n  appHierarchy.getFlattenedHierarchy = () => flattenHierarchy(appHierarchy, []);\n  return appHierarchy.getFlattenedHierarchy();\n};\n\nexport const getLastPartInKey = key => last(splitKey(key));\n\nexport const getNodesInPath = appHierarchy => key => $(appHierarchy, [\n  getFlattenedHierarchy,\n  filter(n => new RegExp(`${n.pathRegx()}`).test(key)),\n]);\n\nexport const getExactNodeForKey = appHierarchy => key => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => new RegExp(`${n.pathRegx()}$`).test(key)),\n]);\n\nexport const getNodeForCollectionPath = appHierarchy => collectionKey => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => (isCollectionRecord(n)\n                   && new RegExp(`${n.collectionPathRegx()}$`).test(collectionKey))),\n]);\n\nexport const hasMatchingAncestor = ancestorPredicate => decendantNode => switchCase(\n\n  [node => isNothing(node.parent()),\n    constant(false)],\n\n  [node => ancestorPredicate(node.parent()),\n    constant(true)],\n\n  [defaultCase,\n    node => hasMatchingAncestor(ancestorPredicate)(node.parent())],\n\n)(decendantNode);\n\nexport const getNode = (appHierarchy, nodeKey) => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => n.nodeKey() === nodeKey\n                  || (isCollectionRecord(n)\n                      && n.collectionNodeKey() === nodeKey)),\n]);\n\nexport const getCollectionNode = (appHierarchy, nodeKey) => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => (isCollectionRecord(n)\n                    && n.collectionNodeKey() === nodeKey)),\n]);\n\nexport const getNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => {\n  const nodeByKey = getExactNodeForKey(appHierarchy)(keyOrNodeKey);\n  return isNothing(nodeByKey)\n    ? getNode(appHierarchy, keyOrNodeKey)\n    : nodeByKey;\n};\n\nexport const getCollectionNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => {\n  const nodeByKey = getNodeForCollectionPath(appHierarchy)(keyOrNodeKey);\n  return isNothing(nodeByKey)\n    ? getCollectionNode(appHierarchy, keyOrNodeKey)\n    : nodeByKey;\n};\n\nexport const isNode = (appHierarchy, key) => isSomething(getExactNodeForKey(appHierarchy)(key));\n\nexport const getActualKeyOfParent = (parentNodeKey, actualChildKey) => \n  $(actualChildKey, [\n    splitKey,\n    take(splitKey(parentNodeKey).length),\n    ks => joinKey(...ks),\n  ]);\n\nexport const getParentKey = (key) => {\n  return $(key, [\n    splitKey,\n    take(splitKey(key).length - 1),\n    joinKey,\n  ]);\n};\n\nexport const isKeyAncestorOf = ancestorKey => decendantNode => hasMatchingAncestor(p => p.nodeKey() === ancestorKey)(decendantNode);\n\nexport const hasNoMatchingAncestors = parentPredicate => node => !hasMatchingAncestor(parentPredicate)(node);\n\nexport const findField = (recordNode, fieldName) => find(f => f.name == fieldName)(recordNode.fields);\n\nexport const isAncestor = decendant => ancestor => isKeyAncestorOf(ancestor.nodeKey())(decendant);\n\nexport const isDecendant = ancestor => decendant => isAncestor(decendant)(ancestor);\n\nexport const getRecordNodeId = recordKey => $(recordKey, [\n  splitKey,\n  last,\n  getRecordNodeIdFromId,\n]);\n\nexport const getRecordNodeIdFromId = recordId => $(recordId, [split('-'), first, parseInt]);\n\nexport const getRecordNodeById = (hierarchy, recordId) => $(hierarchy, [\n  getFlattenedHierarchy,\n  find(n => isRecord(n)\n                    && n.nodeId === getRecordNodeIdFromId(recordId)),\n]);\n\nexport const recordNodeIdIsAllowed = indexNode => nodeId => indexNode.allowedRecordNodeIds.length === 0\n    || includes(nodeId)(indexNode.allowedRecordNodeIds);\n\nexport const recordNodeIsAllowed = indexNode => recordNode => recordNodeIdIsAllowed(indexNode)(recordNode.nodeId);\n\nexport const getAllowedRecordNodesForIndex = (appHierarchy, indexNode) => {\n  const recordNodes = $(appHierarchy, [\n    getFlattenedHierarchy,\n    filter(isRecord),\n  ]);\n\n  if (isGlobalIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(recordNodeIsAllowed(indexNode)),\n    ]);\n  }\n\n  if (isAncestorIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(isDecendant(indexNode.parent())),\n      filter(recordNodeIsAllowed(indexNode)),\n    ]);\n  }\n\n  if (isReferenceIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(n => some(fieldReversesReferenceToIndex(indexNode))(n.fields)),\n    ]);\n  }\n};\n\nexport const getNodeFromNodeKeyHash = hierarchy => hash => $(hierarchy, [\n  getFlattenedHierarchy,\n  find(n => getHashCode(n.nodeKey()) === hash),\n]);\n\nexport const isRecord = node => isSomething(node) && node.type === 'record';\nexport const isSingleRecord = node => isRecord(node) && node.isSingle;\nexport const isCollectionRecord = node => isRecord(node) && !node.isSingle;\nexport const isIndex = node => isSomething(node) && node.type === 'index';\nexport const isaggregateGroup = node => isSomething(node) && node.type === 'aggregateGroup';\nexport const isShardedIndex = node => isIndex(node) && isNonEmptyString(node.getShardName);\nexport const isRoot = node => isSomething(node) && node.isRoot();\nexport const isDecendantOfARecord = hasMatchingAncestor(isRecord);\nexport const isGlobalIndex = node => isIndex(node) && isRoot(node.parent());\nexport const isReferenceIndex = node => isIndex(node) && node.indexType === indexTypes.reference;\nexport const isAncestorIndex = node => isIndex(node) && node.indexType === indexTypes.ancestor;\n\nexport const fieldReversesReferenceToNode = node => field => field.type === 'reference'\n    && intersection(field.typeOptions.reverseIndexNodeKeys)(map(i => i.nodeKey())(node.indexes))\n      .length > 0;\n\nexport const fieldReversesReferenceToIndex = indexNode => field => field.type === 'reference'\n    && intersection(field.typeOptions.reverseIndexNodeKeys)([indexNode.nodeKey()])\n      .length > 0;\n\nexport default {\n  getLastPartInKey,\n  getNodesInPath,\n  getExactNodeForKey,\n  hasMatchingAncestor,\n  getNode,\n  getNodeByKeyOrNodeKey,\n  isNode,\n  getActualKeyOfParent,\n  getParentKey,\n  isKeyAncestorOf,\n  hasNoMatchingAncestors,\n  findField,\n  isAncestor,\n  isDecendant,\n  getRecordNodeId,\n  getRecordNodeIdFromId,\n  getRecordNodeById,\n  recordNodeIdIsAllowed,\n  recordNodeIsAllowed,\n  getAllowedRecordNodesForIndex,\n  getNodeFromNodeKeyHash,\n  isRecord,\n  isCollectionRecord,\n  isIndex,\n  isaggregateGroup,\n  isShardedIndex,\n  isRoot,\n  isDecendantOfARecord,\n  isGlobalIndex,\n  isReferenceIndex,\n  isAncestorIndex,\n  fieldReversesReferenceToNode,\n  fieldReversesReferenceToIndex,\n  getFlattenedHierarchy,\n};\n","import { merge } from 'lodash';\nimport {\n  constant, isUndefined, has,\n  mapValues, cloneDeep,\n} from 'lodash/fp';\nimport { isNotEmpty } from '../common';\n\nexport const getSafeFieldParser = (tryParse, defaultValueFunctions) => (field, record) => {\n  if (has(field.name)(record)) {\n    return getSafeValueParser(tryParse, defaultValueFunctions)(record[field.name]);\n  }\n  return defaultValueFunctions[field.getUndefinedValue]();\n};\n\nexport const getSafeValueParser = (tryParse, defaultValueFunctions) => (value) => {\n  const parsed = tryParse(value);\n  if (parsed.success) {\n    return parsed.value;\n  }\n  return defaultValueFunctions.default();\n};\n\nexport const getNewValue = (tryParse, defaultValueFunctions) => (field) => {\n  const getInitialValue = isUndefined(field) || isUndefined(field.getInitialValue)\n    ? 'default'\n    : field.getInitialValue;\n\n  return has(getInitialValue)(defaultValueFunctions)\n    ? defaultValueFunctions[getInitialValue]()\n    : getSafeValueParser(tryParse, defaultValueFunctions)(getInitialValue);\n};\n\nexport const typeFunctions = specificFunctions => merge({\n  value: constant,\n  null: constant(null),\n}, specificFunctions);\n\nexport const validateTypeConstraints = validationRules => async (field, record, context) => {\n  const fieldValue = record[field.name];\n  const validateRule = async r => (!await r.isValid(fieldValue, field.typeOptions, context)\n    ? r.getMessage(fieldValue, field.typeOptions)\n    : '');\n\n  const errors = [];\n  for (const r of validationRules) {\n    const err = await validateRule(r);\n    if (isNotEmpty(err)) errors.push(err);\n  }\n\n  return errors;\n};\n\nconst getDefaultOptions = mapValues(v => v.defaultValue);\n\nexport const makerule = (isValid, getMessage) => ({ isValid, getMessage });\nexport const parsedFailed = val => ({ success: false, value: val });\nexport const parsedSuccess = val => ({ success: true, value: val });\nexport const getDefaultExport = (name, tryParse, functions, options, validationRules, sampleValue, stringify) => ({\n  getNew: getNewValue(tryParse, functions),\n  safeParseField: getSafeFieldParser(tryParse, functions),\n  safeParseValue: getSafeValueParser(tryParse, functions),\n  tryParse,\n  name,\n  getDefaultOptions: () => getDefaultOptions(cloneDeep(options)),\n  optionDefinitions: options,\n  validateTypeConstraints: validateTypeConstraints(validationRules),\n  sampleValue,\n  stringify: val => (val === null || val === undefined\n    ? '' : stringify(val)),\n  getDefaultValue: functions.default,\n});\n","import {\n  constant, isString,\n  isNull, includes, isBoolean,\n} from 'lodash/fp';\nimport {\n  typeFunctions,\n  makerule, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toBoolOrNull, toNumberOrNull,\n  isSafeInteger, isArrayOfString,\n} from '../common';\n\nconst stringFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst stringTryParse = switchCase(\n  [isString, parsedSuccess],\n  [isNull, parsedSuccess],\n  [defaultCase, v => parsedSuccess(v.toString())],\n);\n\nconst options = {\n  maxLength: {\n    defaultValue: null,\n    isValid: n => n === null || isSafeInteger(n) && n > 0,\n    requirementDescription: 'max length must be null (no limit) or a greater than zero integer',\n    parse: toNumberOrNull,\n  },\n  values: {\n    defaultValue: null,\n    isValid: v => v === null || (isArrayOfString(v) && v.length > 0 && v.length < 10000),\n    requirementDescription: \"'values' must be null (no values) or an arry of at least one string\",\n    parse: s => s,\n  },\n  allowDeclaredValuesOnly: {\n    defaultValue: false,\n    isValid: isBoolean,\n    requirementDescription: 'allowDeclaredValuesOnly must be true or false',\n    parse: toBoolOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.maxLength === null || val.length <= opts.maxLength,\n    (val, opts) => `value exceeds maximum length of ${opts.maxLength}`),\n  makerule(async (val, opts) => val === null\n                           || opts.allowDeclaredValuesOnly === false\n                           || includes(val)(opts.values),\n  (val) => `\"${val}\" does not exist in the list of allowed values`),\n];\n\nexport default getDefaultExport(\n  'string',\n  stringTryParse,\n  stringFunctions,\n  options,\n  typeConstraints,\n  'abcde',\n  str => str,\n);\n","import { constant, isBoolean, isNull } from 'lodash/fp';\nimport {\n  typeFunctions,\n  makerule, parsedFailed, parsedSuccess,\n  getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, isOneOf, toBoolOrNull,\n} from '../common';\n\nconst boolFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst boolTryParse = switchCase(\n  [isBoolean, parsedSuccess],\n  [isNull, parsedSuccess],\n  [isOneOf('true', '1', 'yes', 'on'), () => parsedSuccess(true)],\n  [isOneOf('false', '0', 'no', 'off'), () => parsedSuccess(false)],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  allowNulls: {\n    defaultValue: true,\n    isValid: isBoolean,\n    requirementDescription: 'must be a true or false',\n    parse: toBoolOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => opts.allowNulls === true || val !== null,\n    () => 'field cannot be null'),\n];\n\nexport default getDefaultExport(\n  'bool', boolTryParse, boolFunctions,\n  options, typeConstraints, true, JSON.stringify,\n);\n","import {\n  constant, isNumber, isString, isNull,\n} from 'lodash/fp';\nimport {\n  makerule, typeFunctions,\n  parsedFailed, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toNumberOrNull,\n  isSafeInteger,\n} from '../common';\n\nconst numberFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst parseStringtoNumberOrNull = (s) => {\n  const num = Number(s);\n  return isNaN(num) ? parsedFailed(s) : parsedSuccess(num);\n};\n\nconst numberTryParse = switchCase(\n  [isNumber, parsedSuccess],\n  [isString, parseStringtoNumberOrNull],\n  [isNull, parsedSuccess],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  maxValue: {\n    defaultValue: Number.MAX_SAFE_INTEGER,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a valid integer',\n    parse: toNumberOrNull,\n  },\n  minValue: {\n    defaultValue: 0 - Number.MAX_SAFE_INTEGER,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a valid integer',\n    parse: toNumberOrNull,\n  },\n  decimalPlaces: {\n    defaultValue: 0,\n    isValid: n => isSafeInteger(n) && n >= 0,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n};\n\nconst getDecimalPlaces = (val) => {\n  const splitDecimal = val.toString().split('.');\n  if (splitDecimal.length === 1) return 0;\n  return splitDecimal[1].length;\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue,\n    (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`),\n  makerule(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue,\n    (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`),\n  makerule(async (val, opts) => val === null || opts.decimalPlaces >= getDecimalPlaces(val),\n    (val, opts) => `value (${val.toString()}) must have ${opts.decimalPlaces} decimal places or less`),\n];\n\nexport default getDefaultExport(\n  'number',\n  numberTryParse,\n  numberFunctions,\n  options,\n  typeConstraints,\n  1,\n  num => num.toString(),\n);\n","import {\n  constant, isDate, isString, isNull\n} from 'lodash/fp';\nimport {\n  makerule, typeFunctions,\n  parsedFailed, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toDateOrNull,\n} from '../common';\n\nconst dateFunctions = typeFunctions({\n  default: constant(null),\n  now: () => new Date(),\n});\n\nconst isValidDate = d => d instanceof Date && !isNaN(d);\n\nconst parseStringToDate = s => switchCase(\n  [isValidDate, parsedSuccess],\n  [defaultCase, parsedFailed],\n)(new Date(s));\n\n\nconst dateTryParse = switchCase(\n  [isDate, parsedSuccess],\n  [isString, parseStringToDate],\n  [isNull, parsedSuccess],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  maxValue: {\n    defaultValue: new Date(32503680000000),\n    isValid: isDate,\n    requirementDescription: 'must be a valid date',\n    parse: toDateOrNull,\n  },\n  minValue: {\n    defaultValue: new Date(-8520336000000),\n    isValid: isDate,\n    requirementDescription: 'must be a valid date',\n    parse: toDateOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue,\n    (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`),\n  makerule(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue,\n    (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`),\n];\n\nexport default getDefaultExport(\n  'datetime',\n  dateTryParse,\n  dateFunctions,\n  options,\n  typeConstraints,\n  new Date(1984, 4, 1),\n  date => JSON.stringify(date).replace(new RegExp('\"', 'g'), ''),\n);\n","import { \n  map,  constant, isArray \n} from 'lodash/fp';\nimport {\n  typeFunctions, makerule,\n  parsedFailed, getDefaultExport, parsedSuccess,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toNumberOrNull,\n  $$, isSafeInteger,\n} from '../common';\n\nconst arrayFunctions = () => typeFunctions({\n  default: constant([]),\n});\n\nconst mapToParsedArrary = type => $$(\n  map(i => type.safeParseValue(i)),\n  parsedSuccess,\n);\n\nconst arrayTryParse = type => switchCase(\n  [isArray, mapToParsedArrary(type)],\n  [defaultCase, parsedFailed],\n);\n\nconst typeName = type => `array<${type}>`;\n\n\nconst options = {\n  maxLength: {\n    defaultValue: 10000,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n  minLength: {\n    defaultValue: 0,\n    isValid: n => isSafeInteger(n) && n >= 0,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || val.length >= opts.minLength,\n    (val, opts) => `must choose ${opts.minLength} or more options`),\n  makerule(async (val, opts) => val === null || val.length <= opts.maxLength,\n    (val, opts) => `cannot choose more than ${opts.maxLength} options`),\n];\n\nexport default type => getDefaultExport(\n  typeName(type.name),\n  arrayTryParse(type),\n  arrayFunctions(type),\n  options,\n  typeConstraints,\n  [type.sampleValue],\n  JSON.stringify,\n);\n","import {\n  isString, isObjectLike,\n  isNull, has, isEmpty,\n} from 'lodash/fp';\nimport {\n  typeFunctions, makerule,\n  parsedSuccess, getDefaultExport,\n  parsedFailed,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase,\n  isNonEmptyString, isArrayOfString,\n} from '../common';\n\nconst referenceNothing = () => ({ key: '' });\n\nconst referenceFunctions = typeFunctions({\n  default: referenceNothing,\n});\n\nconst hasStringValue = (ob, path) => has(path)(ob)\n    && isString(ob[path]);\n\nconst isObjectWithKey = v => isObjectLike(v)\n    && hasStringValue(v, 'key');\n\nconst tryParseFromString = s => {\n\n  try {\n    const asObj = JSON.parse(s);\n    if(isObjectWithKey) {\n      return parsedSuccess(asObj);\n    }\n  }\n  catch(_) {\n    // EMPTY\n  }\n\n  return parsedFailed(s);\n}\n\nconst referenceTryParse = v => switchCase(\n  [isObjectWithKey, parsedSuccess],\n  [isString, tryParseFromString],\n  [isNull, () => parsedSuccess(referenceNothing())],\n  [defaultCase, parsedFailed],\n)(v);\n\nconst options = {\n  indexNodeKey: {\n    defaultValue: null,\n    isValid: isNonEmptyString,\n    requirementDescription: 'must be a non-empty string',\n    parse: s => s,\n  },\n  displayValue: {\n    defaultValue: '',\n    isValid: isNonEmptyString,\n    requirementDescription: 'must be a non-empty string',\n    parse: s => s,\n  },\n  reverseIndexNodeKeys: {\n    defaultValue: null,\n    isValid: v => isArrayOfString(v) && v.length > 0,\n    requirementDescription: 'must be a non-empty array of strings',\n    parse: s => s,\n  },\n};\n\nconst isEmptyString = s => isString(s) && isEmpty(s);\n\nconst ensureReferenceExists = async (val, opts, context) => isEmptyString(val.key)\n    || await context.referenceExists(opts, val.key);\n\nconst typeConstraints = [\n  makerule(\n    ensureReferenceExists,\n    (val, opts) => `\"${val[opts.displayValue]}\" does not exist in options list (key: ${val.key})`,\n  ),\n];\n\nexport default getDefaultExport(\n  'reference',\n  referenceTryParse,\n  referenceFunctions,\n  options,\n  typeConstraints,\n  { key: 'key', value: 'value' },\n  JSON.stringify,\n);\n","import {\n  last, has, isString, intersection,\n  isNull, isNumber,\n} from 'lodash/fp';\nimport {\n  typeFunctions, parsedFailed,\n  parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, none,\n  $, splitKey,\n} from '../common';\n\nconst illegalCharacters = '*?\\\\/:<>|\\0\\b\\f\\v';\n\nexport const isLegalFilename = (filePath) => {\n  const fn = fileName(filePath);\n  return fn.length <= 255\n    && intersection(fn.split(''))(illegalCharacters.split('')).length === 0\n    && none(f => f === '..')(splitKey(filePath));\n};\n\nconst fileNothing = () => ({ relativePath: '', size: 0 });\n\nconst fileFunctions = typeFunctions({\n  default: fileNothing,\n});\n\nconst fileTryParse = v => switchCase(\n  [isValidFile, parsedSuccess],\n  [isNull, () => parsedSuccess(fileNothing())],\n  [defaultCase, parsedFailed],\n)(v);\n\nconst fileName = filePath => $(filePath, [\n  splitKey,\n  last,\n]);\n\nconst isValidFile = f => !isNull(f)\n    && has('relativePath')(f) && has('size')(f)\n    && isNumber(f.size)\n    && isString(f.relativePath)\n    && isLegalFilename(f.relativePath);\n\nconst options = {};\n\nconst typeConstraints = [];\n\nexport default getDefaultExport(\n  'file',\n  fileTryParse,\n  fileFunctions,\n  options,\n  typeConstraints,\n  { relativePath: 'some_file.jpg', size: 1000 },\n  JSON.stringify,\n);\n","import {\n  assign, merge, \n} from 'lodash';\nimport {\n  map, isString, isNumber,\n  isBoolean, isDate, keys,\n  isObject, isArray, has\n} from 'lodash/fp';\nimport { $ } from '../common';\nimport { parsedSuccess } from './typeHelpers';\nimport string from './string';\nimport bool from './bool';\nimport number from './number';\nimport datetime from './datetime';\nimport array from './array';\nimport reference from './reference';\nimport file from './file';\nimport { BadRequestError } from '../common/errors';\n\nconst allTypes = () => {\n  const basicTypes = {\n    string, number, datetime, bool, reference, file,\n  };\n\n  const arrays = $(basicTypes, [\n    keys,\n    map((k) => {\n      const kvType = {};\n      const concreteArray = array(basicTypes[k]);\n      kvType[concreteArray.name] = concreteArray;\n      return kvType;\n    }),\n    types => assign({}, ...types),\n  ]);\n\n  return merge({}, basicTypes, arrays);\n};\n\n\nexport const all = allTypes();\n\nexport const getType = (typeName) => {\n  if (!has(typeName)(all)) throw new BadRequestError(`Do not recognise type ${typeName}`);\n  return all[typeName];\n};\n\nexport const getSampleFieldValue = field => getType(field.type).sampleValue;\n\nexport const getNewFieldValue = field => getType(field.type).getNew(field);\n\nexport const safeParseField = (field, record) => getType(field.type).safeParseField(field, record);\n\nexport const validateFieldParse = (field, record) => (has(field.name)(record)\n  ? getType(field.type).tryParse(record[field.name])\n  : parsedSuccess(undefined)); // fields may be undefined by default\n\nexport const getDefaultOptions = type => getType(type).getDefaultOptions();\n\nexport const validateTypeConstraints = async (field, record, context) => await getType(field.type).validateTypeConstraints(field, record, context);\n\nexport const detectType = (value) => {\n  if (isString(value)) return string;\n  if (isBoolean(value)) return bool;\n  if (isNumber(value)) return number;\n  if (isDate(value)) return datetime;\n  if (isArray(value)) return array(detectType(value[0]));\n  if (isObject(value)\n       && has('key')(value)\n       && has('value')(value)) return reference;\n  if (isObject(value)\n        && has('relativePath')(value)\n        && has('size')(value)) return file;\n\n  throw new BadRequestError(`cannot determine type: ${JSON.stringify(value)}`);\n};\n","import { clone, find, split } from 'lodash/fp';\nimport { joinKey, $ } from '../common';\n// 5 minutes\nexport const tempCodeExpiryLength = 5 * 60 * 1000;\n\nexport const AUTH_FOLDER = '/.auth';\nexport const USERS_LIST_FILE = joinKey(AUTH_FOLDER, 'users.json');\nexport const userAuthFile = username => joinKey(AUTH_FOLDER, `auth_${username}.json`);\nexport const USERS_LOCK_FILE = joinKey(AUTH_FOLDER, 'users_lock');\nexport const ACCESS_LEVELS_FILE = joinKey(AUTH_FOLDER, 'access_levels.json');\nexport const ACCESS_LEVELS_LOCK_FILE = joinKey(AUTH_FOLDER, 'access_levels_lock');\n\nexport const permissionTypes = {\n  CREATE_RECORD: 'create record',\n  UPDATE_RECORD: 'update record',\n  READ_RECORD: 'read record',\n  DELETE_RECORD: 'delete record',\n  READ_INDEX: 'read index',\n  MANAGE_INDEX: 'manage index',\n  MANAGE_COLLECTION: 'manage collection',\n  WRITE_TEMPLATES: 'write templates',\n  CREATE_USER: 'create user',\n  SET_PASSWORD: 'set password',\n  CREATE_TEMPORARY_ACCESS: 'create temporary access',\n  ENABLE_DISABLE_USER: 'enable or disable user',\n  WRITE_ACCESS_LEVELS: 'write access levels',\n  LIST_USERS: 'list users',\n  LIST_ACCESS_LEVELS: 'list access levels',\n  EXECUTE_ACTION: 'execute action',\n  SET_USER_ACCESS_LEVELS: 'set user access levels',\n};\n\nexport const getUserByName = (users, name) => $(users, [\n  find(u => u.name.toLowerCase() === name.toLowerCase()),\n]);\n\nexport const stripUserOfSensitiveStuff = (user) => {\n  const stripped = clone(user);\n  delete stripped.tempCode;\n  return stripped;\n};\n\nexport const parseTemporaryCode = fullCode => $(fullCode, [\n  split(':'),\n  parts => ({\n    id: parts[1],\n    code: parts[2],\n  }),\n]);\n","import { values, includes, some } from 'lodash/fp';\nimport { permissionTypes } from './authCommon';\nimport {\n  $, isNothing, apiWrapperSync, events,\n} from '../common';\nimport { getNodeByKeyOrNodeKey, isNode } from '../templateApi/hierarchy';\nimport { alwaysAuthorized } from './permissions';\n\nexport const isAuthorized = app => (permissionType, resourceKey) => apiWrapperSync(\n  app,\n  events.authApi.isAuthorized,\n  alwaysAuthorized,\n  { resourceKey, permissionType },\n  _isAuthorized, app, permissionType, resourceKey,\n);\n\nexport const _isAuthorized = (app, permissionType, resourceKey) => {\n  if (!app.user) {\n    return false;\n  }\n\n  const validType = $(permissionTypes, [\n    values,\n    includes(permissionType),\n  ]);\n\n  if (!validType) {\n    return false;\n  }\n\n  const permMatchesResource = (userperm) => {\n    const nodeKey = isNothing(resourceKey)\n      ? null\n      : isNode(app.hierarchy, resourceKey)\n        ? getNodeByKeyOrNodeKey(\n          app.hierarchy, resourceKey,\n        ).nodeKey()\n        : resourceKey;\n\n    return (userperm.type === permissionType)\n        && (\n          isNothing(resourceKey)\n            || nodeKey === userperm.nodeKey\n        );\n  };\n\n  return $(app.user.permissions, [\n    some(permMatchesResource),\n  ]);\n};\n","import { permissionTypes } from './authCommon';\nimport { isAuthorized } from './isAuthorized';\n\nexport const temporaryAccessPermissions = () => ([{ type: permissionTypes.SET_PASSWORD }]);\n\nconst nodePermission = type => ({\n  add: (nodeKey, accessLevel) => accessLevel.permissions.push({ type, nodeKey }),\n  isAuthorized: resourceKey => app => isAuthorized(app)(type, resourceKey),\n  isNode: true,\n  get: nodeKey => ({ type, nodeKey }),\n});\n\nconst staticPermission = type => ({\n  add: accessLevel => accessLevel.permissions.push({ type }),\n  isAuthorized: app => isAuthorized(app)(type),\n  isNode: false,\n  get: () => ({ type }),\n});\n\nconst createRecord = nodePermission(permissionTypes.CREATE_RECORD);\n\nconst updateRecord = nodePermission(permissionTypes.UPDATE_RECORD);\n\nconst deleteRecord = nodePermission(permissionTypes.DELETE_RECORD);\n\nconst readRecord = nodePermission(permissionTypes.READ_RECORD);\n\nconst writeTemplates = staticPermission(permissionTypes.WRITE_TEMPLATES);\n\nconst createUser = staticPermission(permissionTypes.CREATE_USER);\n\nconst setPassword = staticPermission(permissionTypes.SET_PASSWORD);\n\nconst readIndex = nodePermission(permissionTypes.READ_INDEX);\n\nconst manageIndex = staticPermission(permissionTypes.MANAGE_INDEX);\n\nconst manageCollection = staticPermission(permissionTypes.MANAGE_COLLECTION);\n\nconst createTemporaryAccess = staticPermission(permissionTypes.CREATE_TEMPORARY_ACCESS);\n\nconst enableDisableUser = staticPermission(permissionTypes.ENABLE_DISABLE_USER);\n\nconst writeAccessLevels = staticPermission(permissionTypes.WRITE_ACCESS_LEVELS);\n\nconst listUsers = staticPermission(permissionTypes.LIST_USERS);\n\nconst listAccessLevels = staticPermission(permissionTypes.LIST_ACCESS_LEVELS);\n\nconst setUserAccessLevels = staticPermission(permissionTypes.SET_USER_ACCESS_LEVELS);\n\nconst executeAction = nodePermission(permissionTypes.EXECUTE_ACTION);\n\nexport const alwaysAuthorized = () => true;\n\nexport const permission = {\n  createRecord,\n  updateRecord,\n  deleteRecord,\n  readRecord,\n  writeTemplates,\n  createUser,\n  setPassword,\n  readIndex,\n  createTemporaryAccess,\n  enableDisableUser,\n  writeAccessLevels,\n  listUsers,\n  listAccessLevels,\n  manageIndex,\n  manageCollection,\n  executeAction,\n  setUserAccessLevels,\n};\n","import {\n  keyBy, mapValues,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { \n  getNodeForCollectionPath, isSingleRecord \n} from '../templateApi/hierarchy';\nimport { getNewFieldValue } from '../types';\nimport {\n  $, joinKey, safeKey, apiWrapperSync, events,\n} from '../common';\nimport { permission } from '../authApi/permissions';\n\nexport const getNew = app => (collectionKey, recordTypeName) => {\n  const recordNode = getRecordNode(app, collectionKey, recordTypeName);\n  collectionKey=safeKey(collectionKey);\n  return apiWrapperSync(\n    app,\n    events.recordApi.getNew,\n    permission.createRecord.isAuthorized(recordNode.nodeKey()),\n    { collectionKey, recordTypeName },\n    _getNew, recordNode, collectionKey,\n  );\n};\n\nexport const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey);\n\nconst getRecordNode = (app, collectionKey) => {\n  collectionKey = safeKey(collectionKey);\n  return getNodeForCollectionPath(app.hierarchy)(collectionKey);\n};\n\nexport const getNewChild = app => (recordKey, collectionName, recordTypeName) => \n  getNew(app)(joinKey(recordKey, collectionName), recordTypeName);\n\nexport const constructRecord = (recordNode, getFieldValue, collectionKey) => {\n  const record = $(recordNode.fields, [\n    keyBy('name'),\n    mapValues(getFieldValue),\n  ]);\n\n  record.id = `${recordNode.nodeId}-${generate()}`;\n  record.key = isSingleRecord(recordNode)\n               ? joinKey(collectionKey, recordNode.name)\n               : joinKey(collectionKey, record.id);\n  record.isNew = true;\n  record.type = recordNode.name;\n  return record;\n};\n","import {\n  flatten, orderBy,\n  filter, isUndefined\n} from 'lodash/fp';\nimport hierarchy, {\n  getFlattenedHierarchy,\n  getCollectionNodeByKeyOrNodeKey,\n  isCollectionRecord, isAncestor,\n} from '../templateApi/hierarchy';\nimport { joinKey, safeKey, $ } from '../common';\nimport { getCollectionDir } from \"../recordApi/recordInfo\";\n\nexport const RECORDS_PER_FOLDER = 1000;\nexport const allIdChars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_-';\n\n// this should never be changed - ever \n// - existing databases depend on the order of chars this string\n\n/**\n * folderStructureArray should return an array like\n * - [1] = all records fit into one folder\n * - [2] = all records fite into 2 folders\n * - [64, 3] = all records fit into 64 * 3 folders\n * - [64, 64, 10] = all records fit into 64 * 64 * 10 folder\n * (there are 64 possible chars in allIsChars) \n*/\nexport const folderStructureArray = (recordNode) => {\n\n  const totalFolders = Math.ceil(recordNode.estimatedRecordCount / 1000);\n  const folderArray = [];\n  let levelCount = 1;\n  while(64**levelCount < totalFolders) {\n    levelCount += 1;\n    folderArray.push(64);\n  }\n\n  const parentFactor = (64**folderArray.length);\n  if(parentFactor < totalFolders) {\n    folderArray.push(\n      Math.ceil(totalFolders / parentFactor)\n    );\n  }  \n\n  return folderArray;\n\n  /*\n  const maxRecords = currentFolderPosition === 0 \n                     ? RECORDS_PER_FOLDER\n                     : currentFolderPosition * 64 * RECORDS_PER_FOLDER;\n\n  if(maxRecords < recordNode.estimatedRecordCount) {\n    return folderStructureArray(\n            recordNode,\n            [...currentArray, 64], \n            currentFolderPosition + 1);\n  } else {\n    const childFolderCount = Math.ceil(recordNode.estimatedRecordCount / maxRecords );\n    return [...currentArray, childFolderCount]\n  }*/\n}\n\n\nexport const getAllIdsIterator = app => async (collection_Key_or_NodeKey) => {\n  collection_Key_or_NodeKey = safeKey(collection_Key_or_NodeKey);\n  const recordNode = getCollectionNodeByKeyOrNodeKey(\n    app.hierarchy,\n    collection_Key_or_NodeKey,\n  );\n\n  const getAllIdsIteratorForCollectionKey = async (recordNode, collectionKey) => {\n    \n    const folderStructure = folderStructureArray(recordNode)\n\n    let currentFolderContents = [];\n    let currentPosition = [];\n\n    const collectionDir = getCollectionDir(app.hierarchy, collectionKey);\n    const basePath = joinKey(\n      collectionDir, recordNode.nodeId.toString());\n  \n\n    \n    // \"folderStructure\" determines the top, sharding folders\n    // we need to add one, for the collection root folder, which\n    // always  exists \n    const levels = folderStructure.length + 1;\n    const topLevel = levels -1;\n\n   \n    /* populate initial directory structure in form:\n    [\n      {path: \"/a\", contents: [\"b\", \"c\", \"d\"]}, \n      {path: \"/a/b\", contents: [\"e\",\"f\",\"g\"]},\n      {path: \"/a/b/e\", contents: [\"1-abcd\",\"2-cdef\",\"3-efgh\"]}, \n    ]\n    // stores contents on each parent level\n    // top level has ID folders \n    */\n    const firstFolder = async () => {\n\n      let folderLevel = 0;\n\n      const lastPathHasContent = () => \n        folderLevel === 0 \n        || currentFolderContents[folderLevel - 1].contents.length > 0;\n\n\n      while (folderLevel <= topLevel && lastPathHasContent()) {\n\n        let thisPath = basePath;\n        for(let lev = 0; lev < currentPosition.length; lev++) {\n          thisPath = joinKey(\n            thisPath, currentFolderContents[lev].contents[0]);\n        }\n\n        const contentsThisLevel = \n          await app.datastore.getFolderContents(thisPath);\n        currentFolderContents.push({\n            contents:contentsThisLevel, \n            path: thisPath\n        });   \n\n        // should start as something like [0,0]\n        if(folderLevel < topLevel)\n          currentPosition.push(0); \n\n        folderLevel+=1;\n      }\n\n      return (currentPosition.length === levels - 1);\n    }  \n\n    const isOnLastFolder = level => {\n      \n      const result =  currentPosition[level] === currentFolderContents[level].contents.length - 1;\n      return result;\n    }\n    \n    const getNextFolder = async (lev=undefined) => {\n      lev = isUndefined(lev) ? topLevel : lev;\n      const parentLev = lev - 1;\n\n      if(parentLev < 0) return false;\n      \n      if(isOnLastFolder(parentLev)) { \n        return await getNextFolder(parentLev);\n      }\n\n      const newPosition = currentPosition[parentLev] + 1;\n      currentPosition[parentLev] = newPosition;\n      \n      const nextFolder = joinKey(\n        currentFolderContents[parentLev].path,\n        currentFolderContents[parentLev].contents[newPosition]);\n      currentFolderContents[lev].contents = await app.datastore.getFolderContents(\n        nextFolder\n      );\n      currentFolderContents[lev].path = nextFolder;\n\n      if(lev !== topLevel) {\n      \n        // we just advanced a parent folder, so now need to\n        // do the same to the next levels\n        let loopLevel = lev + 1;\n        while(loopLevel <= topLevel) {\n          const loopParentLevel = loopLevel-1;\n          \n          currentPosition[loopParentLevel] = 0;\n          const nextLoopFolder = joinKey(\n            currentFolderContents[loopParentLevel].path,\n            currentFolderContents[loopParentLevel].contents[0]);\n          currentFolderContents[loopLevel].contents = await app.datastore.getFolderContents(\n            nextLoopFolder\n          );\n          currentFolderContents[loopLevel].path = nextLoopFolder;\n          loopLevel+=1;\n        }\n      }\n\n      // true ==has more ids... (just loaded more)\n      return true;\n    }\n\n\n    const idsCurrentFolder = () => \n      currentFolderContents[currentFolderContents.length - 1].contents;\n\n    const fininshedResult = ({ done: true, result: { ids: [], collectionKey } });\n\n    let hasStarted = false;\n    let hasMore = true;\n    const getIdsFromCurrentfolder = async () => {\n\n      if(!hasMore) {\n        return fininshedResult;\n      }\n\n      if(!hasStarted) {\n        hasMore = await firstFolder();\n        hasStarted = true;\n        return ({\n          result: {\n            ids: idsCurrentFolder(),\n            collectionKey\n          },\n          done: false\n        })\n      }\n\n      hasMore = await getNextFolder();\n      \n      return ({\n        result: {\n          ids: hasMore ? idsCurrentFolder() : [],\n          collectionKey\n        },\n        done: !hasMore\n      });\n    }\n\n    return getIdsFromCurrentfolder;\n    \n  };\n\n  const ancestors = $(getFlattenedHierarchy(app.hierarchy), [\n    filter(isCollectionRecord),\n    filter(n => isAncestor(recordNode)(n)\n                    || n.nodeKey() === recordNode.nodeKey()),\n    orderBy([n => n.nodeKey().length], ['asc']),\n  ]); // parents first\n\n  const traverseForIteraterators = async (parentRecordKey = '', currentNodeIndex = 0) => {\n    const currentNode = ancestors[currentNodeIndex];\n    const currentCollectionKey = joinKey(\n      parentRecordKey,\n      currentNode.collectionName,\n    );\n    if (currentNode.nodeKey() === recordNode.nodeKey()) {\n      return [\n        await getAllIdsIteratorForCollectionKey(\n          currentNode,\n          currentCollectionKey,\n        )];\n    }\n    const allIterators = [];\n    const currentIterator = await getAllIdsIteratorForCollectionKey(\n      currentNode,\n      currentCollectionKey,\n    );\n\n    let ids = await currentIterator();\n    while (ids.done === false) {\n      for (const id of ids.result.ids) {\n        allIterators.push(\n          await traverseForIteraterators(\n            joinKey(currentCollectionKey, id),\n            currentNodeIndex + 1,\n          ),\n        );\n      }\n\n      ids = await currentIterator();\n    }\n\n    return flatten(allIterators);\n  };\n\n  const iteratorsArray = await traverseForIteraterators();\n  let currentIteratorIndex = 0;\n  return async () => {\n    if (iteratorsArray.length === 0) { return { done: true, result: [] }; }\n    const innerResult = await iteratorsArray[currentIteratorIndex]();\n    if (!innerResult.done) { return innerResult; }\n    if (currentIteratorIndex == iteratorsArray.length - 1) {\n      return { done: true, result: innerResult.result };\n    }\n    currentIteratorIndex++;\n    return { done: false, result: innerResult.result };\n  };\n};\n\n\nexport default getAllIdsIterator;\n","import { \n  getExactNodeForKey, getActualKeyOfParent, \n  isRoot, isSingleRecord, getNodeForCollectionPath\n} from '../templateApi/hierarchy';\nimport {\nreduce, find, filter, take\n} from 'lodash/fp';\nimport {\n$, getFileFromKey, joinKey, safeKey, keySep\n} from '../common';\nimport { \n    folderStructureArray, allIdChars \n} from \"../indexing/allIds\";\n\nexport const getRecordInfo = (hierarchy, key) => {\n  const recordNode = getExactNodeForKey(hierarchy)(key);\n  const pathInfo = getRecordDirectory(recordNode, key);\n  const dir = joinKey(pathInfo.base, ...pathInfo.subdirs);\n\n  return {\n    recordJson: recordJson(dir),\n    files: files(dir),\n    child:(name) => joinKey(dir, name),\n    key: safeKey(key),\n    recordNode, pathInfo, dir\n  };\n}\n\nexport const getCollectionDir = (hierarchy, collectionKey) => {\n  const recordNode = getNodeForCollectionPath(hierarchy)(collectionKey);\n  const dummyRecordKey = joinKey(collectionKey, \"1-abcd\");\n  const pathInfo = getRecordDirectory(recordNode, dummyRecordKey);\n  return pathInfo.base;\n}\n\nconst recordJson = (dir) => \n  joinKey(dir, \"record.json\")\n\nconst files = (dir) => \n  joinKey(dir, \"files\")\n\nconst getRecordDirectory = (recordNode, key) => {\n  const id = getFileFromKey(key);\n  \n  const traverseParentKeys = (n, parents=[]) => {\n    if(isRoot(n)) return parents;\n    const k = getActualKeyOfParent(n.nodeKey(), key);\n    const thisNodeDir = {\n      node:n,\n      relativeDir: joinKey(\n        recordRelativeDirectory(n, getFileFromKey(k)))\n    };\n    return traverseParentKeys(\n      n.parent(), \n      [thisNodeDir, ...parents]);\n  }\n\n  const parentDirs = $(recordNode.parent(), [\n    traverseParentKeys,\n    reduce((key, item) => {\n      return joinKey(key, item.node.collectionName, item.relativeDir)\n    }, keySep)\n  ]);\n\n  const subdirs = isSingleRecord(recordNode)\n                  ? []\n                  : recordRelativeDirectory(recordNode, id);\n  const base = isSingleRecord(recordNode)\n               ? joinKey(parentDirs, recordNode.name)\n               : joinKey(parentDirs, recordNode.collectionName);\n\n  return ({\n    subdirs, base\n  });\n}\n\nconst recordRelativeDirectory = (recordNode, id) => {\n  const folderStructure = folderStructureArray(recordNode);\n  const strippedId = id.substring(recordNode.nodeId.toString().length + 1);\n  const subfolders = $(folderStructure, [\n    reduce((result, currentCount) => {\n      result.folders.push(\n          folderForChar(strippedId[result.level], currentCount)\n      );\n      return {level:result.level+1, folders:result.folders};\n    }, {level:0, folders:[]}),\n    f => f.folders,\n    filter(f => !!f)\n  ]);\n\n  return [recordNode.nodeId.toString(), ...subfolders, id]\n}\n\nconst folderForChar = (char, folderCount) => \n  folderCount === 1 ? \"\"\n  : $(folderCount, [\n      idFoldersForFolderCount,\n      find(f => f.includes(char))\n    ]);\n\nconst idFoldersForFolderCount = (folderCount) => {\n  const charRangePerShard = 64 / folderCount;\n  const idFolders = [];\n  let index = 0;\n  let currentIdsShard = '';\n  while (index < 64) {\n    currentIdsShard += allIdChars[index];\n    if ((index + 1) % charRangePerShard === 0) {\n      idFolders.push(currentIdsShard);\n      currentIdsShard = '';\n    }\n    index++;\n  }\n    \n    return idFolders;\n};\n\n","import {\n  keyBy, mapValues, filter, \n  map, includes, last,\n} from 'lodash/fp';\nimport { getExactNodeForKey, getNode } from '../templateApi/hierarchy';\nimport { safeParseField } from '../types';\nimport {\n  $, splitKey, safeKey, isNonEmptyString,\n  apiWrapper, events, joinKey,\n} from '../common';\nimport { mapRecord } from '../indexing/evaluate';\nimport { permission } from '../authApi/permissions';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const getRecordFileName = key => joinKey(key, 'record.json');\n\nexport const load = app => async key => {\n  key = safeKey(key);\n  return apiWrapper(\n    app,\n    events.recordApi.load,\n    permission.readRecord.isAuthorized(key),\n    { key },\n    _load, app, key,\n  );\n}\n\nexport const _loadFromInfo = async (app, recordInfo, keyStack = []) => {\n  const key = recordInfo.key;\n  const {recordNode, recordJson} = recordInfo;\n  const storedData = await app.datastore.loadJson(recordJson);\n\n  const loadedRecord = $(recordNode.fields, [\n    keyBy('name'),\n    mapValues(f => safeParseField(f, storedData)),\n  ]);\n\n  const newKeyStack = [...keyStack, key];\n\n  const references = $(recordNode.fields, [\n    filter(f => f.type === 'reference'\n                    && isNonEmptyString(loadedRecord[f.name].key)\n                    && !includes(loadedRecord[f.name].key)(newKeyStack)),\n    map(f => ({\n      promise: _load(app, loadedRecord[f.name].key, newKeyStack),\n      index: getNode(app.hierarchy, f.typeOptions.indexNodeKey),\n      field: f,\n    })),\n  ]);\n\n  if (references.length > 0) {\n    const refRecords = await Promise.all(\n      map(p => p.promise)(references),\n    );\n\n    for (const ref of references) {\n      loadedRecord[ref.field.name] = mapRecord(\n        refRecords[references.indexOf(ref)],\n        ref.index,\n      );\n    }\n  }\n\n  loadedRecord.transactionId = storedData.transactionId;\n  loadedRecord.isNew = false;\n  loadedRecord.key = key;\n  loadedRecord.id = $(key, [splitKey, last]);\n  loadedRecord.type = recordNode.name;\n  return loadedRecord;\n};\n\nexport const _load = async (app, key, keyStack = []) => \n  _loadFromInfo(\n    app,\n    getRecordInfo(app.hierarchy, key),\n    keyStack);\n\n\nexport default load;\n","// adapted from https://github.com/dex4er/js-promise-readable\n// thanks :)\n  \nexport const promiseReadableStream = stream => {\n   \n    let _errored;\n\n    const _errorHandler = err => {\n        _errored = err;\n    };\n\n    stream.on(\"error\", _errorHandler);\n  \n    const read = (size) => {\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err)\n        }\n  \n        if (!stream.readable || stream.closed || stream.destroyed) {\n          return resolve();\n        }\n  \n        const readableHandler = () => {\n          const chunk = stream.read(size);\n  \n          if (chunk) {\n            removeListeners();\n            resolve(chunk);\n          }\n        }\n  \n        const closeHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const endHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const errorHandler = (err) => {\n          _errored = undefined;\n          removeListeners();\n          reject(err);\n        }\n  \n        const removeListeners = () => {\n          stream.removeListener(\"close\", closeHandler);\n          stream.removeListener(\"error\", errorHandler);\n          stream.removeListener(\"end\", endHandler);\n          stream.removeListener(\"readable\", readableHandler);\n        }\n  \n        stream.on(\"close\", closeHandler);\n        stream.on(\"end\", endHandler);\n        stream.on(\"error\", errorHandler);\n        stream.on(\"readable\", readableHandler);\n  \n        readableHandler();\n      });\n    }\n  \n  \n    const destroy = () => {\n      if (stream) {\n        if (_errorHandler) {\n          stream.removeListener(\"error\", _errorHandler);\n        }\n        if (typeof stream.destroy === \"function\") {\n          stream.destroy();\n        }\n      }\n    };\n  \n    return {read, destroy, stream};\n  }\n  \n  export default promiseReadableStream\n  ","import { compileCode } from '@nx-js/compiler-util';\nimport {\n  filter, includes, map, last,\n} from 'lodash/fp';\nimport {\n  getActualKeyOfParent, isGlobalIndex,\n  getParentKey, isShardedIndex,\n  getExactNodeForKey,\n} from '../templateApi/hierarchy';\nimport {\n  joinKey, isNonEmptyString, splitKey, $,\n} from '../common';\n\nexport const getIndexedDataKey = (indexNode, indexDir, record) => {\n  \n  const getShardName = (indexNode, record) => {\n    const shardNameFunc = compileCode(indexNode.getShardName);\n    try {\n      return shardNameFunc({ record });\n    } catch(e) {\n      const errorDetails = `shardCode: ${indexNode.getShardName} :: record: ${JSON.stringify(record)} :: `\n      e.message = \"Error running index shardname func: \" + errorDetails + e.message;\n      throw e;\n    }\n  };\n\n  const shardName = isNonEmptyString(indexNode.getShardName)\n    ? `${getShardName(indexNode, record)}.csv`\n    : 'index.csv';\n\n  return joinKey(indexDir, shardName);\n};\n\nexport const getShardKeysInRange = async (app, indexNode, indexDir, startRecord = null, endRecord = null) => {\n  const startShardName = !startRecord\n    ? null\n    : shardNameFromKey(\n      getIndexedDataKey(\n        indexNode,\n        indexDir,\n        startRecord,\n      ),\n    );\n\n  const endShardName = !endRecord\n    ? null\n    : shardNameFromKey(\n      getIndexedDataKey(\n        indexNode,\n        indexDir,\n        endRecord,\n      ),\n    );\n\n  return $(await getShardMap(app.datastore, indexDir), [\n    filter(k => (startRecord === null || k >= startShardName)\n                    && (endRecord === null || k <= endShardName)),\n    map(k => joinKey(indexDir, `${k}.csv`)),\n  ]);\n};\n\nexport const ensureShardNameIsInShardMap = async (store, indexDir, indexedDataKey) => {\n  const map = await getShardMap(store, indexDir);\n  const shardName = shardNameFromKey(indexedDataKey);\n  if (!includes(shardName)(map)) {\n    map.push(shardName);\n    await writeShardMap(store, indexDir, map);\n  }\n};\n\nexport const getShardMap = async (datastore, indexDir) => {\n  const shardMapKey = getShardMapKey(indexDir);\n  try {\n    return await datastore.loadJson(shardMapKey);\n  } catch (_) {\n    await datastore.createJson(shardMapKey, []);\n    return [];\n  }\n};\n\nexport const writeShardMap = async (datastore, indexDir, shardMap) => await datastore.updateJson(\n  getShardMapKey(indexDir),\n  shardMap,\n);\n\nexport const getAllShardKeys = async (app, indexNode, indexDir) =>\n  await getShardKeysInRange(app, indexNode, indexDir);\n\nexport const getShardMapKey = indexDir => joinKey(indexDir, 'shardMap.json');\n\nexport const getUnshardedIndexDataKey = indexDir => joinKey(indexDir, 'index.csv');\n\nexport const createIndexFile = async (datastore, indexedDataKey, index) => {\n  if (isShardedIndex(index)) {\n    const indexDir = getParentKey(indexedDataKey);\n    const shardMap = await getShardMap(datastore, indexDir);\n    shardMap.push(\n      shardNameFromKey(indexedDataKey),\n    );\n    await writeShardMap(datastore, indexDir, shardMap);\n  }\n  await datastore.createFile(indexedDataKey, '');\n};\n\nexport const shardNameFromKey = key => $(key, [\n  splitKey,\n  last,\n]).replace('.csv', '');\n\nexport const getIndexKey_BasedOnDecendant = (decendantKey, indexNode) => {\n  if (isGlobalIndex(indexNode)) { return `${indexNode.nodeKey()}`; }\n\n  const indexedDataParentKey = getActualKeyOfParent(\n    indexNode.parent().nodeKey(),\n    decendantKey,\n  );\n\n  return joinKey(\n    indexedDataParentKey,\n    indexNode.name,\n  );\n};\n","import {\n  has, keys, map, orderBy,\n  filter, concat, reverse,\n} from 'lodash/fp';\nimport { getAllowedRecordNodesForIndex } from '../templateApi/hierarchy';\nimport { mapRecord } from './evaluate';\nimport { constructRecord } from '../recordApi/getNew';\nimport { getSampleFieldValue, detectType, all } from '../types';\nimport { $ } from '../common';\n\nexport const generateSchema = (hierarchy, indexNode) => {\n  const recordNodes = getAllowedRecordNodesForIndex(hierarchy, indexNode);\n  const mappedRecords = $(recordNodes, [\n    map(n => mapRecord(createSampleRecord(n), indexNode)),\n  ]);\n\n  // always has record key and sort key\n  const schema = {\n    sortKey: all.string,\n    key: all.string,\n  };\n\n  const fieldsHas = has(schema);\n  const setField = (fieldName, value) => {\n    if (value === null || value === undefined) { return; }\n\n    const thisType = detectType(value);\n    if (fieldsHas(fieldName)) {\n      if (schema[fieldName] !== thisType) {\n        schema[fieldName] = all.string;\n      }\n    } else {\n      schema[fieldName] = thisType;\n    }\n  };\n\n  for (const mappedRec of mappedRecords) {\n    for (const f in mappedRec) {\n      setField(f, mappedRec[f]);\n    }\n  }\n\n  // returing an array of {name, type}\n  return $(schema, [\n    keys,\n    map(k => ({ name: k, type: schema[k].name })),\n    filter(s => s.name !== 'sortKey'),\n    orderBy('name', ['desc']), // reverse aplha\n    concat([{ name: 'sortKey', type: all.string.name }]), // sortKey on end\n    reverse, // sortKey first, then rest are alphabetical\n  ]);\n};\n\nconst createSampleRecord = recordNode => constructRecord(\n  recordNode,\n  getSampleFieldValue,\n  recordNode.parent().nodeKey(),\n);\n","export default (typeof global !== \"undefined\" ? global :\n            typeof self !== \"undefined\" ? self :\n            typeof window !== \"undefined\" ? window : {});\n","\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\nvar inited = false;\nfunction init () {\n  inited = true;\n  var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\n  for (var i = 0, len = code.length; i < len; ++i) {\n    lookup[i] = code[i]\n    revLookup[code.charCodeAt(i)] = i\n  }\n\n  revLookup['-'.charCodeAt(0)] = 62\n  revLookup['_'.charCodeAt(0)] = 63\n}\n\nexport function toByteArray (b64) {\n  if (!inited) {\n    init();\n  }\n  var i, j, l, tmp, placeHolders, arr\n  var len = b64.length\n\n  if (len % 4 > 0) {\n    throw new Error('Invalid string. Length must be a multiple of 4')\n  }\n\n  // the number of equal signs (place holders)\n  // if there are two placeholders, than the two characters before it\n  // represent one byte\n  // if there is only one, then the three characters before it represent 2 bytes\n  // this is just a cheap hack to not do indexOf twice\n  placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n\n  // base64 is 4/3 + up to two characters of the original data\n  arr = new Arr(len * 3 / 4 - placeHolders)\n\n  // if there are placeholders, only get up to the last complete 4 chars\n  l = placeHolders > 0 ? len - 4 : len\n\n  var L = 0\n\n  for (i = 0, j = 0; i < l; i += 4, j += 3) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n    arr[L++] = (tmp >> 16) & 0xFF\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  if (placeHolders === 2) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n    arr[L++] = tmp & 0xFF\n  } else if (placeHolders === 1) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  return arr\n}\n\nfunction tripletToBase64 (num) {\n  return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n  var tmp\n  var output = []\n  for (var i = start; i < end; i += 3) {\n    tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n    output.push(tripletToBase64(tmp))\n  }\n  return output.join('')\n}\n\nexport function fromByteArray (uint8) {\n  if (!inited) {\n    init();\n  }\n  var tmp\n  var len = uint8.length\n  var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n  var output = ''\n  var parts = []\n  var maxChunkLength = 16383 // must be multiple of 3\n\n  // go through the array every three bytes, we'll deal with trailing stuff later\n  for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n    parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n  }\n\n  // pad the end with zeros, but make sure to not forget the extra bytes\n  if (extraBytes === 1) {\n    tmp = uint8[len - 1]\n    output += lookup[tmp >> 2]\n    output += lookup[(tmp << 4) & 0x3F]\n    output += '=='\n  } else if (extraBytes === 2) {\n    tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n    output += lookup[tmp >> 10]\n    output += lookup[(tmp >> 4) & 0x3F]\n    output += lookup[(tmp << 2) & 0x3F]\n    output += '='\n  }\n\n  parts.push(output)\n\n  return parts.join('')\n}\n","\nexport function read (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexport function write (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","var toString = {}.toString;\n\nexport default Array.isArray || function (arr) {\n  return toString.call(arr) == '[object Array]';\n};\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n/* eslint-disable no-proto */\n\n\nimport * as base64 from './base64'\nimport * as ieee754 from './ieee754'\nimport isArray from './isArray'\n\nexport var INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n *   - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n *     See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *   - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n *   - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n *     incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n  ? global.TYPED_ARRAY_SUPPORT\n  : true\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nvar _kMaxLength = kMaxLength()\nexport {_kMaxLength as kMaxLength};\nfunction typedArraySupport () {\n  return true;\n  // rollup issues\n  // try {\n  //   var arr = new Uint8Array(1)\n  //   arr.__proto__ = {\n  //     __proto__: Uint8Array.prototype,\n  //     foo: function () { return 42 }\n  //   }\n  //   return arr.foo() === 42 && // typed array instances can be augmented\n  //       typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n  //       arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  // } catch (e) {\n  //   return false\n  // }\n}\n\nfunction kMaxLength () {\n  return Buffer.TYPED_ARRAY_SUPPORT\n    ? 0x7fffffff\n    : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n  if (kMaxLength() < length) {\n    throw new RangeError('Invalid typed array length')\n  }\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = new Uint8Array(length)\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    if (that === null) {\n      that = new Buffer(length)\n    }\n    that.length = length\n  }\n\n  return that\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nexport function Buffer (arg, encodingOrOffset, length) {\n  if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n    return new Buffer(arg, encodingOrOffset, length)\n  }\n\n  // Common case.\n  if (typeof arg === 'number') {\n    if (typeof encodingOrOffset === 'string') {\n      throw new Error(\n        'If encoding is specified then the first argument must be a string'\n      )\n    }\n    return allocUnsafe(this, arg)\n  }\n  return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n  arr.__proto__ = Buffer.prototype\n  return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n  if (typeof value === 'number') {\n    throw new TypeError('\"value\" argument must not be a number')\n  }\n\n  if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n    return fromArrayBuffer(that, value, encodingOrOffset, length)\n  }\n\n  if (typeof value === 'string') {\n    return fromString(that, value, encodingOrOffset)\n  }\n\n  return fromObject(that, value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n  return from(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n  Buffer.prototype.__proto__ = Uint8Array.prototype\n  Buffer.__proto__ = Uint8Array\n  if (typeof Symbol !== 'undefined' && Symbol.species &&\n      Buffer[Symbol.species] === Buffer) {\n    // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n    // Object.defineProperty(Buffer, Symbol.species, {\n    //   value: null,\n    //   configurable: true\n    // })\n  }\n}\n\nfunction assertSize (size) {\n  if (typeof size !== 'number') {\n    throw new TypeError('\"size\" argument must be a number')\n  } else if (size < 0) {\n    throw new RangeError('\"size\" argument must not be negative')\n  }\n}\n\nfunction alloc (that, size, fill, encoding) {\n  assertSize(size)\n  if (size <= 0) {\n    return createBuffer(that, size)\n  }\n  if (fill !== undefined) {\n    // Only pay attention to encoding if it's a string. This\n    // prevents accidentally sending in a number that would\n    // be interpretted as a start offset.\n    return typeof encoding === 'string'\n      ? createBuffer(that, size).fill(fill, encoding)\n      : createBuffer(that, size).fill(fill)\n  }\n  return createBuffer(that, size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n  return alloc(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n  assertSize(size)\n  that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < size; ++i) {\n      that[i] = 0\n    }\n  }\n  return that\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n  return allocUnsafe(null, size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n  return allocUnsafe(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') {\n    encoding = 'utf8'\n  }\n\n  if (!Buffer.isEncoding(encoding)) {\n    throw new TypeError('\"encoding\" must be a valid string encoding')\n  }\n\n  var length = byteLength(string, encoding) | 0\n  that = createBuffer(that, length)\n\n  var actual = that.write(string, encoding)\n\n  if (actual !== length) {\n    // Writing a hex string, for example, that contains invalid characters will\n    // cause everything after the first invalid character to be ignored. (e.g.\n    // 'abxxcd' will be treated as 'ab')\n    that = that.slice(0, actual)\n  }\n\n  return that\n}\n\nfunction fromArrayLike (that, array) {\n  var length = array.length < 0 ? 0 : checked(array.length) | 0\n  that = createBuffer(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n  array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n  if (byteOffset < 0 || array.byteLength < byteOffset) {\n    throw new RangeError('\\'offset\\' is out of bounds')\n  }\n\n  if (array.byteLength < byteOffset + (length || 0)) {\n    throw new RangeError('\\'length\\' is out of bounds')\n  }\n\n  if (byteOffset === undefined && length === undefined) {\n    array = new Uint8Array(array)\n  } else if (length === undefined) {\n    array = new Uint8Array(array, byteOffset)\n  } else {\n    array = new Uint8Array(array, byteOffset, length)\n  }\n\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = array\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that = fromArrayLike(that, array)\n  }\n  return that\n}\n\nfunction fromObject (that, obj) {\n  if (internalIsBuffer(obj)) {\n    var len = checked(obj.length) | 0\n    that = createBuffer(that, len)\n\n    if (that.length === 0) {\n      return that\n    }\n\n    obj.copy(that, 0, 0, len)\n    return that\n  }\n\n  if (obj) {\n    if ((typeof ArrayBuffer !== 'undefined' &&\n        obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n      if (typeof obj.length !== 'number' || isnan(obj.length)) {\n        return createBuffer(that, 0)\n      }\n      return fromArrayLike(that, obj)\n    }\n\n    if (obj.type === 'Buffer' && isArray(obj.data)) {\n      return fromArrayLike(that, obj.data)\n    }\n  }\n\n  throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < kMaxLength()` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= kMaxLength()) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + kMaxLength().toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nexport function SlowBuffer (length) {\n  if (+length != length) { // eslint-disable-line eqeqeq\n    length = 0\n  }\n  return Buffer.alloc(+length)\n}\nBuffer.isBuffer = isBuffer;\nfunction internalIsBuffer (b) {\n  return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n  if (!internalIsBuffer(a) || !internalIsBuffer(b)) {\n    throw new TypeError('Arguments must be Buffers')\n  }\n\n  if (a === b) return 0\n\n  var x = a.length\n  var y = b.length\n\n  for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n    if (a[i] !== b[i]) {\n      x = a[i]\n      y = b[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'latin1':\n    case 'binary':\n    case 'base64':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function concat (list, length) {\n  if (!isArray(list)) {\n    throw new TypeError('\"list\" argument must be an Array of Buffers')\n  }\n\n  if (list.length === 0) {\n    return Buffer.alloc(0)\n  }\n\n  var i\n  if (length === undefined) {\n    length = 0\n    for (i = 0; i < list.length; ++i) {\n      length += list[i].length\n    }\n  }\n\n  var buffer = Buffer.allocUnsafe(length)\n  var pos = 0\n  for (i = 0; i < list.length; ++i) {\n    var buf = list[i]\n    if (!internalIsBuffer(buf)) {\n      throw new TypeError('\"list\" argument must be an Array of Buffers')\n    }\n    buf.copy(buffer, pos)\n    pos += buf.length\n  }\n  return buffer\n}\n\nfunction byteLength (string, encoding) {\n  if (internalIsBuffer(string)) {\n    return string.length\n  }\n  if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n      (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n    return string.byteLength\n  }\n  if (typeof string !== 'string') {\n    string = '' + string\n  }\n\n  var len = string.length\n  if (len === 0) return 0\n\n  // Use a for loop to avoid recursion\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'ascii':\n      case 'latin1':\n      case 'binary':\n        return len\n      case 'utf8':\n      case 'utf-8':\n      case undefined:\n        return utf8ToBytes(string).length\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return len * 2\n      case 'hex':\n        return len >>> 1\n      case 'base64':\n        return base64ToBytes(string).length\n      default:\n        if (loweredCase) return utf8ToBytes(string).length // assume utf8\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n  var loweredCase = false\n\n  // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n  // property of a typed array.\n\n  // This behaves neither like String nor Uint8Array in that we set start/end\n  // to their upper/lower bounds if the value passed is out of range.\n  // undefined is handled specially as per ECMA-262 6th Edition,\n  // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n  if (start === undefined || start < 0) {\n    start = 0\n  }\n  // Return early if start > this.length. Done here to prevent potential uint32\n  // coercion fail below.\n  if (start > this.length) {\n    return ''\n  }\n\n  if (end === undefined || end > this.length) {\n    end = this.length\n  }\n\n  if (end <= 0) {\n    return ''\n  }\n\n  // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n  end >>>= 0\n  start >>>= 0\n\n  if (end <= start) {\n    return ''\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Slice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n  var i = b[n]\n  b[n] = b[m]\n  b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n  var len = this.length\n  if (len % 2 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 16-bits')\n  }\n  for (var i = 0; i < len; i += 2) {\n    swap(this, i, i + 1)\n  }\n  return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n  var len = this.length\n  if (len % 4 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 32-bits')\n  }\n  for (var i = 0; i < len; i += 4) {\n    swap(this, i, i + 3)\n    swap(this, i + 1, i + 2)\n  }\n  return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n  var len = this.length\n  if (len % 8 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 64-bits')\n  }\n  for (var i = 0; i < len; i += 8) {\n    swap(this, i, i + 7)\n    swap(this, i + 1, i + 6)\n    swap(this, i + 2, i + 5)\n    swap(this, i + 3, i + 4)\n  }\n  return this\n}\n\nBuffer.prototype.toString = function toString () {\n  var length = this.length | 0\n  if (length === 0) return ''\n  if (arguments.length === 0) return utf8Slice(this, 0, length)\n  return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n  if (!internalIsBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return true\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n  var str = ''\n  var max = INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max) str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n  if (!internalIsBuffer(target)) {\n    throw new TypeError('Argument must be a Buffer')\n  }\n\n  if (start === undefined) {\n    start = 0\n  }\n  if (end === undefined) {\n    end = target ? target.length : 0\n  }\n  if (thisStart === undefined) {\n    thisStart = 0\n  }\n  if (thisEnd === undefined) {\n    thisEnd = this.length\n  }\n\n  if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n    throw new RangeError('out of range index')\n  }\n\n  if (thisStart >= thisEnd && start >= end) {\n    return 0\n  }\n  if (thisStart >= thisEnd) {\n    return -1\n  }\n  if (start >= end) {\n    return 1\n  }\n\n  start >>>= 0\n  end >>>= 0\n  thisStart >>>= 0\n  thisEnd >>>= 0\n\n  if (this === target) return 0\n\n  var x = thisEnd - thisStart\n  var y = end - start\n  var len = Math.min(x, y)\n\n  var thisCopy = this.slice(thisStart, thisEnd)\n  var targetCopy = target.slice(start, end)\n\n  for (var i = 0; i < len; ++i) {\n    if (thisCopy[i] !== targetCopy[i]) {\n      x = thisCopy[i]\n      y = targetCopy[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n  // Empty buffer means no match\n  if (buffer.length === 0) return -1\n\n  // Normalize byteOffset\n  if (typeof byteOffset === 'string') {\n    encoding = byteOffset\n    byteOffset = 0\n  } else if (byteOffset > 0x7fffffff) {\n    byteOffset = 0x7fffffff\n  } else if (byteOffset < -0x80000000) {\n    byteOffset = -0x80000000\n  }\n  byteOffset = +byteOffset  // Coerce to Number.\n  if (isNaN(byteOffset)) {\n    // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n    byteOffset = dir ? 0 : (buffer.length - 1)\n  }\n\n  // Normalize byteOffset: negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n  if (byteOffset >= buffer.length) {\n    if (dir) return -1\n    else byteOffset = buffer.length - 1\n  } else if (byteOffset < 0) {\n    if (dir) byteOffset = 0\n    else return -1\n  }\n\n  // Normalize val\n  if (typeof val === 'string') {\n    val = Buffer.from(val, encoding)\n  }\n\n  // Finally, search either indexOf (if dir is true) or lastIndexOf\n  if (internalIsBuffer(val)) {\n    // Special case: looking for empty string/buffer always fails\n    if (val.length === 0) {\n      return -1\n    }\n    return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n  } else if (typeof val === 'number') {\n    val = val & 0xFF // Search for a byte value [0-255]\n    if (Buffer.TYPED_ARRAY_SUPPORT &&\n        typeof Uint8Array.prototype.indexOf === 'function') {\n      if (dir) {\n        return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n      } else {\n        return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n      }\n    }\n    return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n  var indexSize = 1\n  var arrLength = arr.length\n  var valLength = val.length\n\n  if (encoding !== undefined) {\n    encoding = String(encoding).toLowerCase()\n    if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n        encoding === 'utf16le' || encoding === 'utf-16le') {\n      if (arr.length < 2 || val.length < 2) {\n        return -1\n      }\n      indexSize = 2\n      arrLength /= 2\n      valLength /= 2\n      byteOffset /= 2\n    }\n  }\n\n  function read (buf, i) {\n    if (indexSize === 1) {\n      return buf[i]\n    } else {\n      return buf.readUInt16BE(i * indexSize)\n    }\n  }\n\n  var i\n  if (dir) {\n    var foundIndex = -1\n    for (i = byteOffset; i < arrLength; i++) {\n      if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n      } else {\n        if (foundIndex !== -1) i -= i - foundIndex\n        foundIndex = -1\n      }\n    }\n  } else {\n    if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n    for (i = byteOffset; i >= 0; i--) {\n      var found = true\n      for (var j = 0; j < valLength; j++) {\n        if (read(arr, i + j) !== read(val, j)) {\n          found = false\n          break\n        }\n      }\n      if (found) return i\n    }\n  }\n\n  return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n  return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; ++i) {\n    var parsed = parseInt(string.substr(i * 2, 2), 16)\n    if (isNaN(parsed)) return i\n    buf[offset + i] = parsed\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n  return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n  // Buffer#write(string)\n  if (offset === undefined) {\n    encoding = 'utf8'\n    length = this.length\n    offset = 0\n  // Buffer#write(string, encoding)\n  } else if (length === undefined && typeof offset === 'string') {\n    encoding = offset\n    length = this.length\n    offset = 0\n  // Buffer#write(string, offset[, length][, encoding])\n  } else if (isFinite(offset)) {\n    offset = offset | 0\n    if (isFinite(length)) {\n      length = length | 0\n      if (encoding === undefined) encoding = 'utf8'\n    } else {\n      encoding = length\n      length = undefined\n    }\n  // legacy write(string, encoding, offset, length) - remove in v0.13\n  } else {\n    throw new Error(\n      'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n    )\n  }\n\n  var remaining = this.length - offset\n  if (length === undefined || length > remaining) length = remaining\n\n  if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n    throw new RangeError('Attempt to write outside buffer bounds')\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'hex':\n        return hexWrite(this, string, offset, length)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Write(this, string, offset, length)\n\n      case 'ascii':\n        return asciiWrite(this, string, offset, length)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Write(this, string, offset, length)\n\n      case 'base64':\n        // Warning: maxLength not taken into account in base64Write\n        return base64Write(this, string, offset, length)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return ucs2Write(this, string, offset, length)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  end = Math.min(buf.length, end)\n  var res = []\n\n  var i = start\n  while (i < end) {\n    var firstByte = buf[i]\n    var codePoint = null\n    var bytesPerSequence = (firstByte > 0xEF) ? 4\n      : (firstByte > 0xDF) ? 3\n      : (firstByte > 0xBF) ? 2\n      : 1\n\n    if (i + bytesPerSequence <= end) {\n      var secondByte, thirdByte, fourthByte, tempCodePoint\n\n      switch (bytesPerSequence) {\n        case 1:\n          if (firstByte < 0x80) {\n            codePoint = firstByte\n          }\n          break\n        case 2:\n          secondByte = buf[i + 1]\n          if ((secondByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n            if (tempCodePoint > 0x7F) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 3:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n            if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 4:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          fourthByte = buf[i + 3]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n            if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n              codePoint = tempCodePoint\n            }\n          }\n      }\n    }\n\n    if (codePoint === null) {\n      // we did not generate a valid codePoint so insert a\n      // replacement char (U+FFFD) and advance only 1 byte\n      codePoint = 0xFFFD\n      bytesPerSequence = 1\n    } else if (codePoint > 0xFFFF) {\n      // encode to utf16 (surrogate pair dance)\n      codePoint -= 0x10000\n      res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n      codePoint = 0xDC00 | codePoint & 0x3FF\n    }\n\n    res.push(codePoint)\n    i += bytesPerSequence\n  }\n\n  return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n  var len = codePoints.length\n  if (len <= MAX_ARGUMENTS_LENGTH) {\n    return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n  }\n\n  // Decode in chunks to avoid \"call stack size exceeded\".\n  var res = ''\n  var i = 0\n  while (i < len) {\n    res += String.fromCharCode.apply(\n      String,\n      codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n    )\n  }\n  return res\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i] & 0x7F)\n  }\n  return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; ++i) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len\n    if (start < 0) start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0) end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start) end = start\n\n  var newBuf\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    newBuf = this.subarray(start, end)\n    newBuf.__proto__ = Buffer.prototype\n  } else {\n    var sliceLen = end - start\n    newBuf = new Buffer(sliceLen, undefined)\n    for (var i = 0; i < sliceLen; ++i) {\n      newBuf[i] = this[i + start]\n    }\n  }\n\n  return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n  if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    checkOffset(offset, byteLength, this.length)\n  }\n\n  var val = this[offset + --byteLength]\n  var mul = 1\n  while (byteLength > 0 && (mul *= 0x100)) {\n    val += this[offset + --byteLength] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n    ((this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var i = byteLength\n  var mul = 1\n  var val = this[offset + --i]\n  while (i > 0 && (mul *= 0x100)) {\n    val += this[offset + --i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80)) return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n    (this[offset + 1] << 8) |\n    (this[offset + 2] << 16) |\n    (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n    (this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!internalIsBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n  if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var mul = 1\n  var i = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n    buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n      (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffffffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n    buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset + 3] = (value >>> 24)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 1] = (value >>> 8)\n    this[offset] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = 0\n  var mul = 1\n  var sub = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  var sub = 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n  if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (targetStart >= target.length) targetStart = target.length\n  if (!targetStart) targetStart = 0\n  if (end > 0 && end < start) end = start\n\n  // Copy 0 bytes; we're done\n  if (end === start) return 0\n  if (target.length === 0 || this.length === 0) return 0\n\n  // Fatal error conditions\n  if (targetStart < 0) {\n    throw new RangeError('targetStart out of bounds')\n  }\n  if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n  if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length) end = this.length\n  if (target.length - targetStart < end - start) {\n    end = target.length - targetStart + start\n  }\n\n  var len = end - start\n  var i\n\n  if (this === target && start < targetStart && targetStart < end) {\n    // descending copy from end\n    for (i = len - 1; i >= 0; --i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    // ascending copy from start\n    for (i = 0; i < len; ++i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    Uint8Array.prototype.set.call(\n      target,\n      this.subarray(start, start + len),\n      targetStart\n    )\n  }\n\n  return len\n}\n\n// Usage:\n//    buffer.fill(number[, offset[, end]])\n//    buffer.fill(buffer[, offset[, end]])\n//    buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n  // Handle string cases:\n  if (typeof val === 'string') {\n    if (typeof start === 'string') {\n      encoding = start\n      start = 0\n      end = this.length\n    } else if (typeof end === 'string') {\n      encoding = end\n      end = this.length\n    }\n    if (val.length === 1) {\n      var code = val.charCodeAt(0)\n      if (code < 256) {\n        val = code\n      }\n    }\n    if (encoding !== undefined && typeof encoding !== 'string') {\n      throw new TypeError('encoding must be a string')\n    }\n    if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n      throw new TypeError('Unknown encoding: ' + encoding)\n    }\n  } else if (typeof val === 'number') {\n    val = val & 255\n  }\n\n  // Invalid ranges are not set to a default, so can range check early.\n  if (start < 0 || this.length < start || this.length < end) {\n    throw new RangeError('Out of range index')\n  }\n\n  if (end <= start) {\n    return this\n  }\n\n  start = start >>> 0\n  end = end === undefined ? this.length : end >>> 0\n\n  if (!val) val = 0\n\n  var i\n  if (typeof val === 'number') {\n    for (i = start; i < end; ++i) {\n      this[i] = val\n    }\n  } else {\n    var bytes = internalIsBuffer(val)\n      ? val\n      : utf8ToBytes(new Buffer(val, encoding).toString())\n    var len = bytes.length\n    for (i = 0; i < end - start; ++i) {\n      this[i + start] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n  // Node converts strings with length < 2 to ''\n  if (str.length < 2) return ''\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n  units = units || Infinity\n  var codePoint\n  var length = string.length\n  var leadSurrogate = null\n  var bytes = []\n\n  for (var i = 0; i < length; ++i) {\n    codePoint = string.charCodeAt(i)\n\n    // is surrogate component\n    if (codePoint > 0xD7FF && codePoint < 0xE000) {\n      // last char was a lead\n      if (!leadSurrogate) {\n        // no lead yet\n        if (codePoint > 0xDBFF) {\n          // unexpected trail\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        } else if (i + 1 === length) {\n          // unpaired lead\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        }\n\n        // valid lead\n        leadSurrogate = codePoint\n\n        continue\n      }\n\n      // 2 leads in a row\n      if (codePoint < 0xDC00) {\n        if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n        leadSurrogate = codePoint\n        continue\n      }\n\n      // valid surrogate pair\n      codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n    } else if (leadSurrogate) {\n      // valid bmp char, but last char was a lead\n      if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n    }\n\n    leadSurrogate = null\n\n    // encode utf8\n    if (codePoint < 0x80) {\n      if ((units -= 1) < 0) break\n      bytes.push(codePoint)\n    } else if (codePoint < 0x800) {\n      if ((units -= 2) < 0) break\n      bytes.push(\n        codePoint >> 0x6 | 0xC0,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x10000) {\n      if ((units -= 3) < 0) break\n      bytes.push(\n        codePoint >> 0xC | 0xE0,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x110000) {\n      if ((units -= 4) < 0) break\n      bytes.push(\n        codePoint >> 0x12 | 0xF0,\n        codePoint >> 0xC & 0x3F | 0x80,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else {\n      throw new Error('Invalid code point')\n    }\n  }\n\n  return bytes\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    if ((units -= 2) < 0) break\n\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  for (var i = 0; i < length; ++i) {\n    if ((i + offset >= dst.length) || (i >= src.length)) break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\nfunction isnan (val) {\n  return val !== val // eslint-disable-line no-self-compare\n}\n\n\n// the following is from is-buffer, also by Feross Aboukhadijeh and with same lisence\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nexport function isBuffer(obj) {\n  return obj != null && (!!obj._isBuffer || isFastBuffer(obj) || isSlowBuffer(obj))\n}\n\nfunction isFastBuffer (obj) {\n  return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n  return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isFastBuffer(obj.slice(0, 0))\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nimport {Buffer} from 'buffer';\nvar isBufferEncoding = Buffer.isEncoding\n  || function(encoding) {\n       switch (encoding && encoding.toLowerCase()) {\n         case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true;\n         default: return false;\n       }\n     }\n\n\nfunction assertEncoding(encoding) {\n  if (encoding && !isBufferEncoding(encoding)) {\n    throw new Error('Unknown encoding: ' + encoding);\n  }\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters. CESU-8 is handled as part of the UTF-8 encoding.\n//\n// @TODO Handling all encodings inside a single object makes it very difficult\n// to reason about this code, so it should be split up in the future.\n// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code\n// points as used by CESU-8.\nexport function StringDecoder(encoding) {\n  this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, '');\n  assertEncoding(encoding);\n  switch (this.encoding) {\n    case 'utf8':\n      // CESU-8 represents each of Surrogate Pair by 3-bytes\n      this.surrogateSize = 3;\n      break;\n    case 'ucs2':\n    case 'utf16le':\n      // UTF-16 represents each of Surrogate Pair by 2-bytes\n      this.surrogateSize = 2;\n      this.detectIncompleteChar = utf16DetectIncompleteChar;\n      break;\n    case 'base64':\n      // Base-64 stores 3 bytes in 4 chars, and pads the remainder.\n      this.surrogateSize = 3;\n      this.detectIncompleteChar = base64DetectIncompleteChar;\n      break;\n    default:\n      this.write = passThroughWrite;\n      return;\n  }\n\n  // Enough space to store all bytes of a single character. UTF-8 needs 4\n  // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate).\n  this.charBuffer = new Buffer(6);\n  // Number of bytes received for the current incomplete multi-byte character.\n  this.charReceived = 0;\n  // Number of bytes expected for the current incomplete multi-byte character.\n  this.charLength = 0;\n};\n\n\n// write decodes the given buffer and returns it as JS string that is\n// guaranteed to not contain any partial multi-byte characters. Any partial\n// character found at the end of the buffer is buffered up, and will be\n// returned when calling write again with the remaining bytes.\n//\n// Note: Converting a Buffer containing an orphan surrogate to a String\n// currently works, but converting a String to a Buffer (via `new Buffer`, or\n// Buffer#write) will replace incomplete surrogates with the unicode\n// replacement character. See https://codereview.chromium.org/121173009/ .\nStringDecoder.prototype.write = function(buffer) {\n  var charStr = '';\n  // if our last write ended with an incomplete multibyte character\n  while (this.charLength) {\n    // determine how many remaining bytes this buffer has to offer for this char\n    var available = (buffer.length >= this.charLength - this.charReceived) ?\n        this.charLength - this.charReceived :\n        buffer.length;\n\n    // add the new bytes to the char buffer\n    buffer.copy(this.charBuffer, this.charReceived, 0, available);\n    this.charReceived += available;\n\n    if (this.charReceived < this.charLength) {\n      // still not enough chars in this buffer? wait for more ...\n      return '';\n    }\n\n    // remove bytes belonging to the current character from the buffer\n    buffer = buffer.slice(available, buffer.length);\n\n    // get the character that was split\n    charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding);\n\n    // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n    var charCode = charStr.charCodeAt(charStr.length - 1);\n    if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n      this.charLength += this.surrogateSize;\n      charStr = '';\n      continue;\n    }\n    this.charReceived = this.charLength = 0;\n\n    // if there are no more bytes in this buffer, just emit our char\n    if (buffer.length === 0) {\n      return charStr;\n    }\n    break;\n  }\n\n  // determine and set charLength / charReceived\n  this.detectIncompleteChar(buffer);\n\n  var end = buffer.length;\n  if (this.charLength) {\n    // buffer the incomplete character bytes we got\n    buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end);\n    end -= this.charReceived;\n  }\n\n  charStr += buffer.toString(this.encoding, 0, end);\n\n  var end = charStr.length - 1;\n  var charCode = charStr.charCodeAt(end);\n  // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n  if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n    var size = this.surrogateSize;\n    this.charLength += size;\n    this.charReceived += size;\n    this.charBuffer.copy(this.charBuffer, size, 0, size);\n    buffer.copy(this.charBuffer, 0, 0, size);\n    return charStr.substring(0, end);\n  }\n\n  // or just emit the charStr\n  return charStr;\n};\n\n// detectIncompleteChar determines if there is an incomplete UTF-8 character at\n// the end of the given buffer. If so, it sets this.charLength to the byte\n// length that character, and sets this.charReceived to the number of bytes\n// that are available for this character.\nStringDecoder.prototype.detectIncompleteChar = function(buffer) {\n  // determine how many bytes we have to check at the end of this buffer\n  var i = (buffer.length >= 3) ? 3 : buffer.length;\n\n  // Figure out if one of the last i bytes of our buffer announces an\n  // incomplete char.\n  for (; i > 0; i--) {\n    var c = buffer[buffer.length - i];\n\n    // See http://en.wikipedia.org/wiki/UTF-8#Description\n\n    // 110XXXXX\n    if (i == 1 && c >> 5 == 0x06) {\n      this.charLength = 2;\n      break;\n    }\n\n    // 1110XXXX\n    if (i <= 2 && c >> 4 == 0x0E) {\n      this.charLength = 3;\n      break;\n    }\n\n    // 11110XXX\n    if (i <= 3 && c >> 3 == 0x1E) {\n      this.charLength = 4;\n      break;\n    }\n  }\n  this.charReceived = i;\n};\n\nStringDecoder.prototype.end = function(buffer) {\n  var res = '';\n  if (buffer && buffer.length)\n    res = this.write(buffer);\n\n  if (this.charReceived) {\n    var cr = this.charReceived;\n    var buf = this.charBuffer;\n    var enc = this.encoding;\n    res += buf.slice(0, cr).toString(enc);\n  }\n\n  return res;\n};\n\nfunction passThroughWrite(buffer) {\n  return buffer.toString(this.encoding);\n}\n\nfunction utf16DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 2;\n  this.charLength = this.charReceived ? 2 : 0;\n}\n\nfunction base64DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 3;\n  this.charLength = this.charReceived ? 3 : 0;\n}\n","import {generateSchema} from \"./indexSchemaCreator\";\nimport { has, isString, difference, find } from \"lodash/fp\";\nimport { Buffer } from \"safe-buffer\";\nimport {StringDecoder} from \"string_decoder\";\nimport {getType} from \"../types\";\nimport { isSomething } from \"../common\";\n\nexport const BUFFER_MAX_BYTES = 524288; // 0.5Mb\n\nexport const CONTINUE_READING_RECORDS = \"CONTINUE_READING\";\nexport const READ_REMAINING_TEXT = \"READ_REMAINING\";\nexport const CANCEL_READ = \"CANCEL\";\n\nexport const getIndexWriter = (hierarchy, indexNode, readableStream, writableStream, end) => {\n    const schema = generateSchema(hierarchy, indexNode);\n\n    return ({\n        read: read(readableStream, schema),\n        updateIndex: updateIndex(readableStream, writableStream, schema, end)\n    });\n};\n\nexport const getIndexReader = (hierarchy, indexNode, readableStream) => \n    read(\n        readableStream, \n        generateSchema(hierarchy, indexNode)\n    );\n\nconst updateIndex = (readableStream, writableStream, schema) => async (itemsToWrite, keysToRemove) => {\n    const write = newOutputWriter(BUFFER_MAX_BYTES, writableStream);\n    const writtenItems = []; \n    await read(readableStream, schema)(\n        async indexedItem => {\n            const updated = find(i => indexedItem.key === i.key)(itemsToWrite);\n            const removed = find(k => indexedItem.key === k)(keysToRemove);\n            \n            if(isSomething(removed)) \n                return CONTINUE_READING_RECORDS;\n\n            if(isSomething(updated)) {\n                const serializedItem =  serializeItem(schema, updated);\n                await write(serializedItem);\n                writtenItems.push(updated);\n            } else {\n                await write(\n                    serializeItem(schema, indexedItem)\n                );\n            } \n\n            return CONTINUE_READING_RECORDS;\n\n        },\n        async text => await write(text)\n    );\n\n    if(writtenItems.length !== itemsToWrite.length) {\n        const toAdd = difference(itemsToWrite, writtenItems);\n        for(let added of toAdd) {\n            await write(\n                serializeItem(schema, added)\n            );\n        }\n    } else if(writtenItems.length === 0) {\n        // potentially are no records\n        await write(\"\");\n    }\n\n    await write();\n    await writableStream.end();\n};\n\nconst read = (readableStream, schema) => async (onGetItem, onGetText) => {\n    const readInput = newInputReader(readableStream);\n    let text = await readInput();\n    let status = CONTINUE_READING_RECORDS;\n    while(text.length > 0) {\n\n        if(status === READ_REMAINING_TEXT) {\n            await onGetText(text);\n            continue;\n        }\n\n        if(status === CANCEL_READ) {\n            return;\n        }\n\n        let rowText = \"\";\n        let currentCharIndex=0;\n        for(let currentChar of text) {\n            rowText += currentChar;\n            if(currentChar === \"\\r\") {\n                status = await onGetItem(\n                    deserializeRow(schema, rowText)\n                );\n                rowText = \"\";\n                if(status === READ_REMAINING_TEXT) {\n                    break;\n                }\n            }\n            currentCharIndex++;\n        }\n\n        if(currentCharIndex < text.length -1) {\n            await onGetText(text.substring(currentCharIndex + 1));\n        }\n\n        text = await readInput();\n    }\n\n    await readableStream.destroy();\n\n};\n\nconst newOutputWriter = (flushBoundary, writableStream) => {\n    \n    let currentBuffer = null;\n\n    return async (text) => {\n\n        if(isString(text) && currentBuffer === null)\n            currentBuffer = Buffer.from(text, \"utf8\");\n        else if(isString(text))\n            currentBuffer = Buffer.concat([\n                currentBuffer,\n                Buffer.from(text, \"utf8\")\n            ]);\n        \n        if(currentBuffer !== null &&\n            (currentBuffer.length > flushBoundary\n             || !isString(text))) {\n\n            await writableStream.write(currentBuffer);\n            currentBuffer = null;\n        }\n    }\n};\n\nconst newInputReader = (readableStream) => {\n\n    const decoder = new StringDecoder('utf8');\n    let remainingBytes = [];\n\n    return async () => {\n\n        let nextBytesBuffer = await readableStream.read(BUFFER_MAX_BYTES);\n        const remainingBuffer = Buffer.from(remainingBytes);\n\n        if(!nextBytesBuffer) nextBytesBuffer = Buffer.from([]);\n\n        const moreToRead = nextBytesBuffer.length === BUFFER_MAX_BYTES;\n\n        const buffer = Buffer.concat(\n            [remainingBuffer, nextBytesBuffer],\n            remainingBuffer.length + nextBytesBuffer.length);\n\n        const text = decoder.write(buffer);\n        remainingBytes = decoder.end(buffer);\n\n        if(!moreToRead && remainingBytes.length > 0) {\n            // if for any reason, we have remaining bytes at the end\n            // of the stream, just discard - dont see why this should\n            // ever happen, but if it does, it could cause a stack overflow\n            remainingBytes = [];\n        }\n\n        return text;\n    };\n};\n\nconst deserializeRow = (schema, rowText) => {\n    let currentPropIndex = 0;\n    let currentCharIndex = 0;\n    let currentValueText = \"\";\n    let isEscaped = false;\n    const item = {};\n\n    const setCurrentProp = () => {\n        const currentProp = schema[currentPropIndex];\n        const type = getType(currentProp.type);\n        const value = currentValueText === \"\"\n                      ? type.getDefaultValue()\n                      : type.safeParseValue(\n                          currentValueText);\n        item[currentProp.name] = value;\n    };\n    \n    while(currentPropIndex < schema.length) {\n\n        if(currentCharIndex < rowText.length) {\n            const currentChar = rowText[currentCharIndex];\n            if(isEscaped) {\n                if(currentChar === \"r\") {\n                    currentValueText += \"\\r\";\n                } else {\n                    currentValueText += currentChar;\n                }\n                isEscaped = false;\n            } else {\n                if(currentChar === \",\") {\n                    setCurrentProp();\n                    currentValueText = \"\";\n                    currentPropIndex++;\n                } else if(currentChar === \"\\\\\") {\n                    isEscaped = true;\n                } else {\n                    currentValueText += currentChar;\n                }\n            }\n            currentCharIndex++; \n        } else {\n            currentValueText = \"\";\n            setCurrentProp();\n            currentPropIndex++;\n        }\n    }\n\n    return item;\n};\n\nexport const serializeItem = (schema, item)  => {\n\n    let rowText = \"\"\n\n    for(let prop of schema) {\n        const type = getType(prop.type);\n        const value = has(prop.name)(item)\n                      ? item[prop.name]\n                      : type.getDefaultValue()\n        \n        const valStr = type.stringify(value);\n\n        for(let i = 0; i < valStr.length; i++) {\n            const currentChar = valStr[i];\n            if(currentChar === \",\" \n               || currentChar === \"\\r\" \n               || currentChar === \"\\\\\") {\n                rowText += \"\\\\\";\n            }\n\n            if(currentChar === \"\\r\") {\n                rowText += \"r\";\n            } else {\n                rowText += currentChar;\n            }\n        }\n\n        rowText += \",\";\n    }\n\n    rowText += \"\\r\";\n    return rowText;\n};","import lunr from 'lunr';\nimport {promiseReadableStream} from \"./promiseReadableStream\";\nimport { createIndexFile } from './sharding';\nimport { generateSchema } from './indexSchemaCreator';\nimport { getIndexReader, CONTINUE_READING_RECORDS } from './serializer';\n\nexport const readIndex = async (hierarchy, datastore, index, indexedDataKey) => {\n  const records = [];\n  const doRead = iterateIndex(\n        async item => {\n      records.push(item);\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => records\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\nexport const searchIndex = async (hierarchy, datastore, index, indexedDataKey, searchPhrase) => {\n  const records = [];\n  const schema = generateSchema(hierarchy, index);\n  const doRead = iterateIndex(\n        async item => {\n      const idx = lunr(function () {\n        this.ref('key');\n        for (const field of schema) {\n          this.field(field.name);\n        }\n        this.add(item);\n      });\n      const searchResults = idx.search(searchPhrase);\n      if (searchResults.length === 1) {\n        item._searchResult = searchResults[0];\n        records.push(item);\n      }\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => records\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\nexport const iterateIndex = (onGetItem, getFinalResult) => async (hierarchy, datastore, index, indexedDataKey) => {\n  try {\n    const readableStream = promiseReadableStream(\n        await datastore.readableFileStream(indexedDataKey)\n    );\n\n    const read = getIndexReader(hierarchy, index, readableStream);\n    await read(onGetItem);\n    return getFinalResult();\n  } catch (e) {\n    if (await datastore.exists(indexedDataKey)) {\n      throw e;\n    } else {\n      await createIndexFile(\n        datastore,\n        indexedDataKey,\n        index,\n      );\n    }\n    return [];\n  }\n};\n","import { getRecordInfo } from \"../recordApi/recordInfo\";\nimport { \n    getParentKey, getLastPartInKey\n} from \"../templateApi/hierarchy\";\nimport { keySep } from \"../common\";\n\nexport const getIndexDir = (hierarchy, indexKey) => {\n\n    const parentKey = getParentKey(indexKey);\n\n    if(parentKey === \"\") return indexKey;\n    if(parentKey === keySep) return indexKey;\n\n    const recordInfo = getRecordInfo(\n        hierarchy, \n        parentKey);\n        \n    return recordInfo.child(\n        getLastPartInKey(indexKey));\n}","import { flatten, merge } from 'lodash/fp';\nimport {\n  safeKey, apiWrapper, $,\n  events, isNonEmptyString,\n} from '../common';\nimport { readIndex, searchIndex } from '../indexing/read';\nimport {\n  getUnshardedIndexDataKey,\n  getShardKeysInRange,\n} from '../indexing/sharding';\nimport {\n  getExactNodeForKey, isIndex,\n  isShardedIndex,\n} from '../templateApi/hierarchy';\nimport { permission } from '../authApi/permissions';\nimport { getIndexDir } from \"./getIndexDir\";\n\nexport const listItems = app => async (indexKey, options) => {\n  indexKey = safeKey(indexKey);\n  return apiWrapper(\n    app,\n    events.indexApi.listItems,\n    permission.readIndex.isAuthorized(indexKey),\n    { indexKey, options },\n    _listItems, app, indexKey, options,\n  );\n}\n\nconst defaultOptions = { rangeStartParams: null, rangeEndParams: null, searchPhrase: null };\n\nconst _listItems = async (app, indexKey, options = defaultOptions) => {\n  const { searchPhrase, rangeStartParams, rangeEndParams } = $({}, [\n    merge(options),\n    merge(defaultOptions),\n  ]);\n\n  const getItems = async indexedDataKey => (isNonEmptyString(searchPhrase)\n    ? await searchIndex(\n      app.hierarchy,\n      app.datastore,\n      indexNode,\n      indexedDataKey,\n      searchPhrase,\n    )\n    : await readIndex(\n      app.hierarchy,\n      app.datastore,\n      indexNode,\n      indexedDataKey,\n    ));\n\n  indexKey = safeKey(indexKey);\n  const indexNode = getExactNodeForKey(app.hierarchy)(indexKey);\n  const indexDir = getIndexDir(app.hierarchy, indexKey);\n\n  if (!isIndex(indexNode)) { throw new Error('supplied key is not an index'); }\n\n  if (isShardedIndex(indexNode)) {\n    const shardKeys = await getShardKeysInRange(\n      app, indexNode, indexDir, rangeStartParams, rangeEndParams,\n    );\n    const items = [];\n    for (const k of shardKeys) {\n      items.push(await getItems(k));\n    }\n    return flatten(items);\n  }\n  return await getItems(\n    getUnshardedIndexDataKey(indexDir),\n  );\n};\n","import { map, isString, has, some } from 'lodash/fp';\nimport {\n  getExactNodeForKey,\n  findField, getNode, isGlobalIndex,\n} from '../templateApi/hierarchy';\nimport { listItems } from '../indexApi/listItems';\nimport {\n  $, apiWrapperSync, events, safeKey\n} from '../common';\nimport { getIndexKey_BasedOnDecendant } from '../indexing/sharding';\nimport { permission } from '../authApi/permissions';\n\nexport const getContext = app => recordKey => {\n  recordKey = safeKey(recordKey);\n  return  apiWrapperSync(\n    app,\n    events.recordApi.getContext,\n    permission.readRecord.isAuthorized(recordKey),\n    { recordKey },\n    _getContext, app, recordKey,\n  );\n}\n\nexport const _getContext = (app, recordKey) => {\n  recordKey = safeKey(recordKey);\n  const recordNode = getExactNodeForKey(app.hierarchy)(recordKey);\n\n  const cachedReferenceIndexes = {};\n\n  const lazyLoadReferenceIndex = async (typeOptions) => {\n    if (!has(typeOptions.indexNodeKey)(cachedReferenceIndexes)) {\n      cachedReferenceIndexes[typeOptions.indexNodeKey] = {\n        typeOptions,\n        data: await readReferenceIndex(\n          app, recordKey, typeOptions,\n        ),\n      };\n    }\n\n    return cachedReferenceIndexes[typeOptions.indexNodeKey];\n  };\n\n  const getTypeOptions = typeOptions_or_fieldName => (isString(typeOptions_or_fieldName)\n    ? findField(recordNode, typeOptions_or_fieldName)\n      .typeOptions\n    : typeOptions_or_fieldName);\n\n  return {\n    referenceExists: async (typeOptions_or_fieldName, key) => {\n      const typeOptions = getTypeOptions(typeOptions_or_fieldName);\n      const { data } = await lazyLoadReferenceIndex(typeOptions);\n      return some(i => i.key === key)(data);\n    },\n    referenceOptions: async (typeOptions_or_fieldName) => {\n      const typeOptions = getTypeOptions(typeOptions_or_fieldName);\n      const { data } = await lazyLoadReferenceIndex(typeOptions);\n      return data;\n    },\n    recordNode,\n  };\n};\n\nconst readReferenceIndex = async (app, recordKey, typeOptions) => {\n  const indexNode = getNode(app.hierarchy, typeOptions.indexNodeKey);\n  const indexKey = isGlobalIndex(indexNode)\n    ? indexNode.nodeKey()\n    : getIndexKey_BasedOnDecendant(\n      recordKey, indexNode,\n    );\n\n  const items = await listItems(app)(indexKey);\n  return $(items, [\n    map(i => ({\n      key: i.key,\n      value: i[typeOptions.displayValue],\n    })),\n  ]);\n};\n","import {\n  map, reduce, filter,\n  isEmpty, flatten, each,\n} from 'lodash/fp';\nimport { compileExpression } from '@nx-js/compiler-util';\nimport _ from 'lodash';\nimport { getExactNodeForKey } from '../templateApi/hierarchy';\nimport { validateFieldParse, validateTypeConstraints } from '../types';\nimport { $, isNothing, isNonEmptyString } from '../common';\nimport { _getContext } from './getContext';\n\nconst fieldParseError = (fieldName, value) => ({\n  fields: [fieldName],\n  message: `Could not parse field ${fieldName}:${value}`,\n});\n\nconst validateAllFieldParse = (record, recordNode) => $(recordNode.fields, [\n  map(f => ({ name: f.name, parseResult: validateFieldParse(f, record) })),\n  reduce((errors, f) => {\n    if (f.parseResult.success) return errors;\n    errors.push(\n      fieldParseError(f.name, f.parseResult.value),\n    );\n    return errors;\n  }, []),\n]);\n\nconst validateAllTypeConstraints = async (record, recordNode, context) => {\n  const errors = [];\n  for (const field of recordNode.fields) {\n    $(await validateTypeConstraints(field, record, context), [\n      filter(isNonEmptyString),\n      map(m => ({ message: m, fields: [field.name] })),\n      each(e => errors.push(e)),\n    ]);\n  }\n  return errors;\n};\n\nconst runRecordValidationRules = (record, recordNode) => {\n  const runValidationRule = (rule) => {\n    const isValid = compileExpression(rule.expressionWhenValid);\n    const expressionContext = { record, _ };\n    return (isValid(expressionContext)\n      ? { valid: true }\n      : ({\n        valid: false,\n        fields: rule.invalidFields,\n        message: rule.messageWhenInvalid,\n      }));\n  };\n\n  return $(recordNode.validationRules, [\n    map(runValidationRule),\n    flatten,\n    filter(r => r.valid === false),\n    map(r => ({ fields: r.fields, message: r.message })),\n  ]);\n};\n\nexport const validate = app => async (record, context) => {\n  context = isNothing(context)\n    ? _getContext(app, record.key)\n    : context;\n\n  const recordNode = getExactNodeForKey(app.hierarchy)(record.key);\n  const fieldParseFails = validateAllFieldParse(record, recordNode);\n\n  // non parsing would cause further issues - exit here\n  if (!isEmpty(fieldParseFails)) { return ({ isValid: false, errors: fieldParseFails }); }\n\n  const recordValidationRuleFails = runRecordValidationRules(record, recordNode);\n  const typeContraintFails = await validateAllTypeConstraints(record, recordNode, context);\n\n  if (isEmpty(fieldParseFails)\n       && isEmpty(recordValidationRuleFails)\n       && isEmpty(typeContraintFails)) {\n    return ({ isValid: true, errors: [] });\n  }\n\n  return ({\n    isValid: false,\n    errors: _.union(fieldParseFails, typeContraintFails, recordValidationRuleFails),\n  });\n};\n","import { filter } from 'lodash/fp';\nimport {\n  getFlattenedHierarchy,\n  isCollectionRecord,\n  isRoot,\n} from '../templateApi/hierarchy';\nimport { $, allTrue, joinKey } from '../common';\n\nconst ensureCollectionIsInitialised = async (datastore, node, dir) => {\n  if (!await datastore.exists(dir)) {\n    await datastore.createFolder(dir);\n    await datastore.createFolder(joinKey(dir, node.nodeId));\n  }\n};\n\nexport const initialiseRootCollections = async (datastore, hierarchy) => {\n  const rootCollectionRecord = allTrue(\n    n => isRoot(n.parent()),\n    isCollectionRecord,\n  );\n\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n\n  const collectionRecords = $(flathierarchy, [\n    filter(rootCollectionRecord),\n  ]);\n\n  for (const col of collectionRecords) {\n    await ensureCollectionIsInitialised(\n      datastore,\n      col,\n      col.collectionPathRegx()\n    );\n  }\n};\n\nexport const initialiseChildCollections = async (app, recordInfo) => {\n  const childCollectionRecords = $(recordInfo.recordNode, [\n    n => n.children,\n    filter(isCollectionRecord),\n  ]);\n\n  for (const child of childCollectionRecords) {\n    await ensureCollectionIsInitialised(\n      app.datastore,\n      child,\n      recordInfo.child(child.collectionName),\n    );\n  }\n};\n","import {\n  joinKey, keySep, getHashCode,\n} from '../common';\nimport { getLastPartInKey } from '../templateApi/hierarchy';\n\nexport const TRANSACTIONS_FOLDER = `${keySep}.transactions`;\nexport const LOCK_FILENAME = 'lock';\nexport const LOCK_FILE_KEY = joinKey(\n  TRANSACTIONS_FOLDER, LOCK_FILENAME,\n);\nexport const idSep = '$';\n\nconst isOfType = typ => trans => trans.transactionType === typ;\n\nexport const CREATE_RECORD_TRANSACTION = 'create';\nexport const UPDATE_RECORD_TRANSACTION = 'update';\nexport const DELETE_RECORD_TRANSACTION = 'delete';\nexport const BUILD_INDEX_TRANSACTION = 'build';\n\nexport const isUpdate = isOfType(UPDATE_RECORD_TRANSACTION);\nexport const isDelete = isOfType(DELETE_RECORD_TRANSACTION);\nexport const isCreate = isOfType(CREATE_RECORD_TRANSACTION);\nexport const isBuildIndex = isOfType(BUILD_INDEX_TRANSACTION);\n\nexport const keyToFolderName = nodeKey => getHashCode(nodeKey);\n\nexport const getTransactionId = (recordId, transactionType, uniqueId) => \n  `${recordId}${idSep}${transactionType}${idSep}${uniqueId}`;\n\nexport const buildIndexFolder = '.BUILD-';\nexport const nodeKeyHashFromBuildFolder = folder => folder.replace(buildIndexFolder, '');\n\nexport const isBuildIndexFolder = key => getLastPartInKey(key).startsWith(buildIndexFolder);\n\nexport const IndexNodeKeyFolder = indexNodeKey => joinKey(\n  TRANSACTIONS_FOLDER,\n  buildIndexFolder + keyToFolderName(indexNodeKey),\n);\n\nexport const IndexNodeKeyBatchFolder = (indexNodeKey, count) => \n  joinKey(IndexNodeKeyFolder(indexNodeKey), Math.floor(count / BUILDINDEX_BATCH_COUNT).toString());\n\nexport const IndexShardKeyFolder = (indexNodeKey, indexShardKey) => \n  joinKey(IndexNodeKeyFolder(indexNodeKey), indexShardKey);\n\nexport const BUILDINDEX_BATCH_COUNT = 1000;\nexport const timeoutMilliseconds = 30 * 1000; // 30 secs\nexport const maxLockRetries = 1;\n","import { generate } from 'shortid';\nimport { joinKey } from '../common';\nimport { getLastPartInKey } from '../templateApi/hierarchy';\nimport {\n  IndexNodeKeyFolder, BUILDINDEX_BATCH_COUNT,\n  IndexNodeKeyBatchFolder, TRANSACTIONS_FOLDER, getTransactionId, CREATE_RECORD_TRANSACTION, UPDATE_RECORD_TRANSACTION,\n  DELETE_RECORD_TRANSACTION, BUILD_INDEX_TRANSACTION,\n} from './transactionsCommon';\n\n\nexport const transactionForCreateRecord = async (app, record) => await transaction(\n  app.datastore, CREATE_RECORD_TRANSACTION,\n  record.key, { record },\n  getTransactionKey_Records,\n);\n\nexport const transactionForUpdateRecord = async (app, oldRecord, newRecord) => await transaction(\n  app.datastore, UPDATE_RECORD_TRANSACTION,\n  newRecord.key, { oldRecord, record: newRecord },\n  getTransactionKey_Records,\n);\n\nexport const transactionForDeleteRecord = async (app, record) => await transaction(\n  app.datastore, DELETE_RECORD_TRANSACTION,\n  record.key, { record },\n  getTransactionKey_Records,\n);\n\nexport const transactionForBuildIndex = async (app, indexNodeKey, recordKey, count) => {\n  const transactionFolder = IndexNodeKeyBatchFolder(indexNodeKey, count);\n  if (count % BUILDINDEX_BATCH_COUNT === 0) {\n    await app.datastore.createFolder(transactionFolder);\n  }\n\n  return await transaction(\n    app.datastore, BUILD_INDEX_TRANSACTION,\n    recordKey, { recordKey },\n    id => joinKey(transactionFolder, id),\n  );\n};\n\nexport const createBuildIndexFolder = async (datastore, indexNodeKey) => await datastore.createFolder(\n  IndexNodeKeyFolder(indexNodeKey),\n);\n\nconst getTransactionKey_Records = id => joinKey(TRANSACTIONS_FOLDER, id);\n\nconst transaction = async (datastore, transactionType, recordKey, data, getTransactionKey) => {\n  const recordId = getLastPartInKey(recordKey);\n  const uniqueId = generate();\n  const id = getTransactionId(\n    recordId, transactionType, uniqueId,\n  );\n\n  const key = getTransactionKey(id);\n\n  const trans = {\n    transactionType,\n    recordKey,\n    ...data,\n    id,\n  };\n\n  await datastore.createJson(\n    key, trans,\n  );\n\n  return trans;\n};\n","import { isShardedIndex } from '../templateApi/hierarchy';\nimport { joinKey } from '../common';\nimport { getShardMapKey, getUnshardedIndexDataKey, createIndexFile } from './sharding';\n\nexport const initialiseIndex = async (datastore, dir, index) => {\n  const indexDir = joinKey(dir, index.name);\n\n  await datastore.createFolder(indexDir);\n\n  if (isShardedIndex(index)) {\n    await datastore.createFile(\n      getShardMapKey(indexDir),\n      '[]',\n    );\n  } else {\n    await createIndexFile(\n      datastore,\n      getUnshardedIndexDataKey(indexDir),\n      index,\n    );\n  }\n};\n","import {\n  cloneDeep, take, takeRight,\n  flatten, map, filter\n} from 'lodash/fp';\nimport { initialiseChildCollections } from '../collectionApi/initialise';\nimport { validate } from './validate';\nimport { _loadFromInfo } from './load';\nimport {\n  apiWrapper, events, $, joinKey,\n} from '../common';\nimport {\n  getFlattenedHierarchy, isRecord, getNode, \n  fieldReversesReferenceToNode,\n} from '../templateApi/hierarchy';\nimport {\n  transactionForCreateRecord,\n  transactionForUpdateRecord,\n} from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { initialiseIndex } from '../indexing/initialiseIndex';\nimport { BadRequestError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const save = app => async (record, context) => apiWrapper(\n  app,\n  events.recordApi.save,\n  record.isNew\n    ? permission.createRecord.isAuthorized(record.key)\n    : permission.updateRecord.isAuthorized(record.key), { record },\n  _save, app, record, context, false,\n);\n\n\nexport const _save = async (app, record, context, skipValidation = false) => {\n  const recordClone = cloneDeep(record);\n  if (!skipValidation) {\n    const validationResult = await validate(app)(recordClone, context);\n    if (!validationResult.isValid) {\n      await app.publish(events.recordApi.save.onInvalid, { record, validationResult });\n      throw new BadRequestError(`Save : Record Invalid : ${\n        JSON.stringify(validationResult.errors)}`);\n    }\n  }\n\n  const recordInfo = getRecordInfo(app.hierarchy, record.key);\n  const {\n    recordNode, pathInfo,\n    recordJson, files,\n  } = recordInfo;\n\n  if (recordClone.isNew) {\n    \n    if(!recordNode)\n      throw new Error(\"Cannot find node for \" + record.key);\n\n    const transaction = await transactionForCreateRecord(\n      app, recordClone,\n    );\n    recordClone.transactionId = transaction.id;\n    await createRecordFolderPath(app.datastore, pathInfo);\n    await app.datastore.createFolder(files);\n    await app.datastore.createJson(recordJson, recordClone);\n    await initialiseReverseReferenceIndexes(app, recordInfo);\n    await initialiseAncestorIndexes(app, recordInfo);\n    await initialiseChildCollections(app, recordInfo);\n    await app.publish(events.recordApi.save.onRecordCreated, {\n      record: recordClone,\n    });\n  } else {\n    const oldRecord = await _loadFromInfo(app, recordInfo);\n    const transaction = await transactionForUpdateRecord(\n      app, oldRecord, recordClone,\n    );\n    recordClone.transactionId = transaction.id;\n    await app.datastore.updateJson(\n      recordJson,\n      recordClone,\n    );\n    await app.publish(events.recordApi.save.onRecordUpdated, {\n      old: oldRecord,\n      new: recordClone,\n    });\n  }\n\n  await app.cleanupTransactions();\n\n  const returnedClone = cloneDeep(recordClone);\n  returnedClone.isNew = false;\n  return returnedClone;\n};\n\nconst initialiseAncestorIndexes = async (app, recordInfo) => {\n  for (const index of recordInfo.recordNode.indexes) {\n    const indexKey = recordInfo.child(index.name);\n    if (!await app.datastore.exists(indexKey)) { \n      await initialiseIndex(app.datastore, recordInfo.dir, index); \n    }\n  }\n};\n\nconst initialiseReverseReferenceIndexes = async (app, recordInfo) => {\n\n  const indexNodes = $(fieldsThatReferenceThisRecord(app, recordInfo.recordNode), [\n    map(f => $(f.typeOptions.reverseIndexNodeKeys, [\n      map(n => getNode(\n        app.hierarchy,\n        n,\n      )),\n    ])),\n    flatten,\n  ]);\n\n  for (const indexNode of indexNodes) {\n    await initialiseIndex(\n      app.datastore, recordInfo.dir, indexNode,\n    );\n  }\n};\n\nconst fieldsThatReferenceThisRecord = (app, recordNode) => $(app.hierarchy, [\n  getFlattenedHierarchy,\n  filter(isRecord),\n  map(n => n.fields),\n  flatten,\n  filter(fieldReversesReferenceToNode(recordNode)),\n]);\n\nconst createRecordFolderPath = async (datastore, pathInfo) => {\n  \n  const recursiveCreateFolder = async (subdirs, dirsThatNeedCreated=undefined) => {\n\n    // iterate backwards through directory hierachy\n    // until we get to a folder that exists, then create the rest\n    // e.g \n    // - some/folder/here\n    // - some/folder\n    // - some\n    const thisFolder = joinKey(pathInfo.base, ...subdirs);\n\n    if(await datastore.exists(thisFolder)) {\n\n      let creationFolder = thisFolder;\n      for(let nextDir of (dirsThatNeedCreated || []) ) {\n        creationFolder = joinKey(creationFolder, nextDir);\n        await datastore.createFolder(creationFolder);\n      }\n\n    } else if(!dirsThatNeedCreated || dirsThatNeedCreated.length > 0) {\n\n      dirsThatNeedCreated = !dirsThatNeedCreated\n                          ? []\n                          :dirsThatNeedCreated;\n      \n      await recursiveCreateFolder(\n        take(subdirs.length - 1)(subdirs),\n        [...takeRight(1)(subdirs), ...dirsThatNeedCreated]\n      );\n    }\n  }\n\n  await recursiveCreateFolder(pathInfo.subdirs);\n\n  return joinKey(pathInfo.base, ...pathInfo.subdirs);\n\n}","import {\n  safeKey, apiWrapper,\n  events, joinKey,\n} from '../common';\nimport { _deleteRecord } from '../recordApi/delete';\nimport { getAllIdsIterator } from '../indexing/allIds';\nimport { permission } from '../authApi/permissions';\nimport { getCollectionDir } from \"../recordApi/recordInfo\";\n\nexport const deleteCollection = (app, disableCleanup = false) => async key => apiWrapper(\n  app,\n  events.collectionApi.delete,\n  permission.manageCollection.isAuthorized,\n  { key },\n  _deleteCollection, app, key, disableCleanup,\n);\n\n/*\n  const recordNode = getCollectionNode(app.hierarchy, key);\n\n*/\n\nexport const _deleteCollection = async (app, key, disableCleanup) => {\n  key = safeKey(key);\n  const collectionDir = getCollectionDir(app.hierarchy, key);\n  await deleteRecords(app, key);\n  await deleteCollectionFolder(app, collectionDir);\n  if (!disableCleanup) { await app.cleanupTransactions(); }\n};\n\nconst deleteCollectionFolder = async (app, dir) => \n  await app.datastore.deleteFolder(dir);\n\nconst deleteRecords = async (app, key) => {\n  \n  const iterate = await getAllIdsIterator(app)(key);\n\n  let ids = await iterate();\n  while (!ids.done) {\n    if (ids.result.collectionKey === key) {\n      for (const id of ids.result.ids) {\n        await _deleteRecord(\n          app,\n          joinKey(key, id),\n          true,\n        );\n      }\n    }\n\n    ids = await iterate();\n  }\n};\n","import {\n  safeKey, apiWrapper,\n  events, joinKey,\n} from '../common';\nimport { _load } from './load';\nimport { _deleteCollection } from '../collectionApi/delete';\nimport {\n  getExactNodeForKey\n} from '../templateApi/hierarchy';\nimport { transactionForDeleteRecord } from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { getRecordInfo } from './recordInfo';\n\nexport const deleteRecord = (app, disableCleanup = false) => async key => {\n  key = safeKey(key);\n  return apiWrapper(\n    app,\n    events.recordApi.delete,\n    permission.deleteRecord.isAuthorized(key),\n    { key },\n    _deleteRecord, app, key, disableCleanup,\n  );\n}\n\n// called deleteRecord because delete is a keyword\nexport const _deleteRecord = async (app, key, disableCleanup) => {\n  const recordInfo = getRecordInfo(app.hierarchy, key);\n  key = recordInfo.key;\n  const node = getExactNodeForKey(app.hierarchy)(key);\n\n  const record = await _load(app, key);\n  await transactionForDeleteRecord(app, record);\n\n  for (const collectionRecord of node.children) {\n    const collectionKey = joinKey(\n      key, collectionRecord.collectionName,\n    );\n    await _deleteCollection(app, collectionKey, true);\n  }\n\n  await app.datastore.deleteFolder(recordInfo.dir);\n\n  if (!disableCleanup) { await app.cleanupTransactions(); }\n};\n\n","import {\n  includes, filter,\n  map, some,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { _loadFromInfo } from './load';\nimport {\n  apiWrapper, events, splitKey,\n  $, joinKey, isNothing, tryAwaitOrIgnore,\n} from '../common';\nimport { getExactNodeForKey } from '../templateApi/hierarchy';\nimport { permission } from '../authApi/permissions';\nimport { isLegalFilename } from '../types/file';\nimport { BadRequestError, ForbiddenError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const uploadFile = app => async (recordKey, readableStream, relativeFilePath) => apiWrapper(\n  app,\n  events.recordApi.uploadFile,\n  permission.updateRecord.isAuthorized(recordKey),\n  { recordKey, readableStream, relativeFilePath },\n  _uploadFile, app, recordKey, readableStream, relativeFilePath,\n);\n\nconst _uploadFile = async (app, recordKey, readableStream, relativeFilePath) => {\n  if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); }\n  if (isNothing(relativeFilePath)) { throw new BadRequestError('file path not supplied'); }\n  if (!isLegalFilename(relativeFilePath)) { throw new BadRequestError('Illegal filename'); }\n\n  const recordInfo = getRecordInfo(app.hierarchy, recordKey);\n  const record = await _loadFromInfo(app, recordInfo);\n\n  const fullFilePath = safeGetFullFilePath(\n    recordInfo.dir, relativeFilePath,\n  );\n\n  const tempFilePath = `${fullFilePath}_${generate()}.temp`;\n\n  const outputStream = await app.datastore.writableFileStream(\n    tempFilePath,\n  );\n\n  return new Promise((resolve,reject) => {\n    readableStream.pipe(outputStream);\n    outputStream.on('error', reject);\n    outputStream.on('finish', resolve);\n  })\n  .then(() => app.datastore.getFileSize(tempFilePath))\n  .then(size => {\n    const isExpectedFileSize = checkFileSizeAgainstFields(\n      app, record, relativeFilePath, size\n    );  \n    if (!isExpectedFileSize) { throw new BadRequestError(`Fields for ${relativeFilePath} do not have expected size: ${join(',')(incorrectFields)}`); }  \n\n  })\n  .then(() => tryAwaitOrIgnore(app.datastore.deleteFile, fullFilePath))\n  .then(() => app.datastore.renameFile(tempFilePath, fullFilePath));\n\n};\n\nconst checkFileSizeAgainstFields = (app, record, relativeFilePath, expectedSize) => {\n  const recordNode = getExactNodeForKey(app.hierarchy)(record.key);\n\n  const incorrectFileFields = $(recordNode.fields, [\n    filter(f => f.type === 'file'\n      && record[f.name].relativePath === relativeFilePath\n      && record[f.name].size !== expectedSize),\n    map(f => f.name),\n  ]);\n\n  const incorrectFileArrayFields = $(recordNode.fields, [\n    filter(a => a.type === 'array<file>'\n      && $(record[a.name], [\n        some(f => record[f.name].relativePath === relativeFilePath\n          && record[f.name].size !== expectedSize),\n      ])),\n    map(f => f.name),\n  ]);\n\n  const incorrectFields = [\n    ...incorrectFileFields,\n    ...incorrectFileArrayFields,\n  ];\n\n  if (incorrectFields.length > 0) {\n    return false;\n  }\n\n  return true;\n};\n\nexport const safeGetFullFilePath = (recordDir, relativeFilePath) => {\n  const naughtyUser = () => { throw new ForbiddenError('naughty naughty'); };\n\n  if (relativeFilePath.startsWith('..')) naughtyUser();\n\n  const pathParts = splitKey(relativeFilePath);\n\n  if (includes('..')(pathParts)) naughtyUser();\n\n  const recordKeyParts = splitKey(recordDir);\n\n  const fullPathParts = [\n    ...recordKeyParts,\n    'files',\n    ...filter(p => p !== '.')(pathParts),\n  ];\n\n  return joinKey(fullPathParts);\n};\n","import { apiWrapper, events, isNothing } from '../common';\nimport { permission } from '../authApi/permissions';\nimport { safeGetFullFilePath } from './uploadFile';\nimport { BadRequestError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const downloadFile = app => async (recordKey, relativePath) => apiWrapper(\n  app,\n  events.recordApi.uploadFile,\n  permission.readRecord.isAuthorized(recordKey),\n  { recordKey, relativePath },//remove dupe key 'recordKey' from object\n  _downloadFile, app, recordKey, relativePath,\n); \n\n\nconst _downloadFile = async (app, recordKey, relativePath) => {\n  if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); }\n  if (isNothing(relativePath)) { throw new BadRequestError('file path not supplied'); }\n\n  const {dir} = getRecordInfo(app.hierarchy, recordKey);\n  return await app.datastore.readableFileStream(\n    safeGetFullFilePath(\n      dir, relativePath,\n    ),\n  );\n};\n","import { find, take, union } from 'lodash/fp';\nimport { getFlattenedHierarchy } from '../templateApi/hierarchy';\nimport { $, splitKey, joinKey } from '../common';\nimport { NotFoundError } from '../common/errors';\n\nexport const customId = app => (nodeName, id) => {\n  const node = $(app.hierarchy, [\n    getFlattenedHierarchy,\n    find(n => n.name === nodeName),\n  ]);\n\n  if (!node) throw new NotFoundError(`Cannot find node ${nodeName}`);\n\n  return `${node.nodeId}-${id}`;\n};\n\nexport const setCustomId = app => (record, id) => {\n  record.id = customId(app)(record.type, id);\n\n  const keyParts = splitKey(record.key);\n\n  record.key = $(keyParts, [\n    take(keyParts.length - 1),\n    union([record.id]),\n    joinKey,\n  ]);\n\n  return record;\n};\n","import { getNew, getNewChild } from './getNew';\nimport { load } from './load';\nimport { validate } from './validate';\nimport { getContext } from './getContext';\nimport { save } from './save';\nimport { deleteRecord } from './delete';\nimport { uploadFile } from './uploadFile';\nimport { downloadFile } from './downloadFile';\nimport { customId, setCustomId } from './customId';\n\nconst api = app => ({\n  getNew: getNew(app),\n  getNewChild: getNewChild(app),\n  save: save(app),\n  load: load(app),\n  delete: deleteRecord(app, false),\n  validate: validate(app),\n  getContext: getContext(app),\n  uploadFile: uploadFile(app),\n  downloadFile: downloadFile(app),\n  customId: customId(app),\n  setCustomId: setCustomId(app),\n});\n\n\nexport const getRecordApi = app => api(app);\n\nexport default getRecordApi;\n","import { getNodeForCollectionPath } from '../templateApi/hierarchy';\nimport {\n  isNothing, safeKey, apiWrapperSync, events,\n} from '../common';\nimport { alwaysAuthorized } from '../authApi/permissions';\n\nexport const getAllowedRecordTypes = app => key => apiWrapperSync(\n  app,\n  events.collectionApi.getAllowedRecordTypes,\n  alwaysAuthorized,\n  { key },\n  _getAllowedRecordTypes, app, key,\n);\n\nconst _getAllowedRecordTypes = (app, key) => {\n  key = safeKey(key);\n  const node = getNodeForCollectionPath(app.hierarchy)(key);\n  return isNothing(node) ? [] : [node.name];\n};\n","import { getAllIdsIterator } from '../indexing/allIds';\nimport { getAllowedRecordTypes } from './getAllowedRecordTypes';\nimport { deleteCollection } from './delete';\n\nexport const getCollectionApi = app => ({\n  getAllowedRecordTypes: getAllowedRecordTypes(app),\n  getAllIdsIterator: getAllIdsIterator(app),\n  delete: deleteCollection(app),\n});\n\nexport default getCollectionApi;\n","import {\n  filter, \n  includes, some,\n} from 'lodash/fp';\nimport { getAllIdsIterator } from '../indexing/allIds';\nimport {\n  getFlattenedHierarchy, getRecordNodeById,\n  getNode, isIndex,\n  isRecord, getAllowedRecordNodesForIndex,\n  fieldReversesReferenceToIndex,\n} from '../templateApi/hierarchy';\nimport {\n  joinKey, apiWrapper, events, $\n} from '../common';\nimport {\n  createBuildIndexFolder,\n  transactionForBuildIndex,\n} from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\n\n\n/** rebuilds an index\n * @param {object} app - the application container\n * @param {string} indexNodeKey - node key of the index, which the index belongs to\n */\nexport const buildIndex = app => async indexNodeKey => apiWrapper(\n  app,\n  events.indexApi.buildIndex,\n  permission.manageIndex.isAuthorized,\n  { indexNodeKey },\n  _buildIndex, app, indexNodeKey,\n);\n\nconst _buildIndex = async (app, indexNodeKey) => {\n  const indexNode = getNode(app.hierarchy, indexNodeKey);\n\n  await createBuildIndexFolder(app.datastore, indexNodeKey);\n\n  if (!isIndex(indexNode)) { throw new BadRequestError('BuildIndex: must supply an indexnode'); }\n\n  if (indexNode.indexType === 'reference') {\n    await buildReverseReferenceIndex(\n      app, indexNode,\n    );\n  } else {\n    await buildHeirarchalIndex(\n      app, indexNode,\n    );\n  }\n\n  await app.cleanupTransactions();\n};\n\nconst buildReverseReferenceIndex = async (app, indexNode) => {\n  // Iterate through all referencING records,\n  // and update referenced index for each record\n  let recordCount = 0;\n  const referencingNodes = $(app.hierarchy, [\n    getFlattenedHierarchy,\n    filter(n => isRecord(n)\n                    && some(fieldReversesReferenceToIndex(indexNode))(n.fields)),\n  ]);\n\n  const createTransactionsForReferencingNode = async (referencingNode) => {\n    const iterateReferencingNodes = await getAllIdsIterator(app)(referencingNode.collectionNodeKey());\n\n    let referencingIdIterator = await iterateReferencingNodes();\n    while (!referencingIdIterator.done) {\n      const { result } = referencingIdIterator;\n      for (const id of result.ids) {\n        const recordKey = joinKey(result.collectionKey, id);\n        await transactionForBuildIndex(app, indexNode.nodeKey(), recordKey, recordCount);\n        recordCount++;\n      }\n      referencingIdIterator = await iterateReferencingNodes();\n    }\n  };\n\n  for (const referencingNode of referencingNodes) {\n    await createTransactionsForReferencingNode(referencingNode);\n  }\n};\n\n/*\nconst getAllowedParentCollectionNodes = (hierarchy, indexNode) => $(getAllowedRecordNodesForIndex(hierarchy, indexNode), [\n  map(n => n.parent()),\n]);\n*/\n\nconst buildHeirarchalIndex = async (app, indexNode) => {\n  let recordCount = 0;\n\n  const createTransactionsForIds = async (collectionKey, ids) => {\n    for (const recordId of ids) {\n      const recordKey = joinKey(collectionKey, recordId);\n\n      const recordNode = getRecordNodeById(\n        app.hierarchy,\n        recordId,\n      );\n\n      if (recordNodeApplies(indexNode)(recordNode)) {\n        await transactionForBuildIndex(\n          app, indexNode.nodeKey(),\n          recordKey, recordCount,\n        );\n        recordCount++;\n      }\n    }\n  };\n\n\n  const collectionRecords = getAllowedRecordNodesForIndex(app.hierarchy, indexNode);\n\n  for (const targetCollectionRecordNode of collectionRecords) {\n    const allIdsIterator = await getAllIdsIterator(app)(targetCollectionRecordNode.collectionNodeKey());\n\n    let allIds = await allIdsIterator();\n    while (allIds.done === false) {\n      await createTransactionsForIds(\n        allIds.result.collectionKey,\n        allIds.result.ids,\n      );\n      allIds = await allIdsIterator();\n    }\n  }\n\n  return recordCount;\n};\n\n// const chooseChildRecordNodeByKey = (collectionNode, recordId) => find(c => recordId.startsWith(c.nodeId))(collectionNode.children);\n\nconst recordNodeApplies = indexNode => recordNode => includes(recordNode.nodeId)(indexNode.allowedRecordNodeIds);\n\n/*\nconst hasApplicableDecendant = (hierarchy, ancestorNode, indexNode) => $(hierarchy, [\n  getFlattenedHierarchy,\n  filter(\n    allTrue(\n      isRecord,\n      isDecendant(ancestorNode),\n      recordNodeApplies(indexNode),\n    ),\n  ),\n]);\n*/\n\n /*\nconst applyAllDecendantRecords = async (app, collection_Key_or_NodeKey,\n  indexNode, indexKey, currentIndexedData,\n  currentIndexedDataKey, recordCount = 0) => {\n  const collectionNode = getCollectionNodeByKeyOrNodeKey(\n    app.hierarchy,\n    collection_Key_or_NodeKey,\n  );\n\n  const allIdsIterator = await getAllIdsIterator(app)(collection_Key_or_NodeKey);\n\n\n  const createTransactionsForIds = async (collectionKey, allIds) => {\n    for (const recordId of allIds) {\n      const recordKey = joinKey(collectionKey, recordId);\n\n      const recordNode = chooseChildRecordNodeByKey(\n        collectionNode,\n        recordId,\n      );\n\n      if (recordNodeApplies(indexNode)(recordNode)) {\n        await transactionForBuildIndex(\n          app, indexNode.nodeKey(),\n          recordKey, recordCount,\n        );\n        recordCount++;\n      }\n\n      if (hasApplicableDecendant(app.hierarchy, recordNode, indexNode)) {\n        for (const childCollectionNode of recordNode.children) {\n          recordCount = await applyAllDecendantRecords(\n            app,\n            joinKey(recordKey, childCollectionNode.collectionName),\n            indexNode, indexKey, currentIndexedData,\n            currentIndexedDataKey, recordCount,\n          );\n        }\n      }\n    }\n  };\n\n  let allIds = await allIdsIterator();\n  while (allIds.done === false) {\n    await createTransactionsForIds(\n      allIds.result.collectionKey,\n      allIds.result.ids,\n    );\n    allIds = await allIdsIterator();\n  }\n\n  return recordCount;\n};\n*/\n\nexport default buildIndex;\n","import { has, isNumber, isUndefined } from 'lodash/fp';\nimport { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  safeKey, apiWrapper,\n  events, isNonEmptyString,\n} from '../common';\nimport { iterateIndex } from '../indexing/read';\nimport {\n  getUnshardedIndexDataKey,\n  getShardKeysInRange,\n} from '../indexing/sharding';\nimport {\n  getExactNodeForKey, isIndex,\n  isShardedIndex,\n} from '../templateApi/hierarchy';\nimport { CONTINUE_READING_RECORDS } from '../indexing/serializer';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\nimport { getIndexDir } from \"./getIndexDir\";\n\nexport const aggregates = app => async (indexKey, rangeStartParams = null, rangeEndParams = null) => apiWrapper(\n  app,\n  events.indexApi.aggregates,\n  permission.readIndex.isAuthorized(indexKey),\n  { indexKey, rangeStartParams, rangeEndParams },\n  _aggregates, app, indexKey, rangeStartParams, rangeEndParams,\n);\n\nconst _aggregates = async (app, indexKey, rangeStartParams, rangeEndParams) => {\n  indexKey = safeKey(indexKey);\n  const indexNode = getExactNodeForKey(app.hierarchy)(indexKey);\n  const indexDir = getIndexDir(app.hierarchy, indexKey);\n\n  if (!isIndex(indexNode)) { throw new BadRequestError('supplied key is not an index'); }\n\n  if (isShardedIndex(indexNode)) {\n    const shardKeys = await getShardKeysInRange(\n      app, indexNode, indexDir, rangeStartParams, rangeEndParams,\n    );\n    let aggregateResult = null;\n    for (const k of shardKeys) {\n      const shardResult = await getAggregates(app.hierarchy, app.datastore, indexNode, k);\n      if (aggregateResult === null) {\n        aggregateResult = shardResult;\n      } else {\n        aggregateResult = mergeShardAggregate(\n          aggregateResult,\n          shardResult,\n        );\n      }\n    }\n    return aggregateResult;\n  }\n  return await getAggregates(\n    app.hierarchy,\n    app.datastore,\n    indexNode,\n    getUnshardedIndexDataKey(indexDir),\n  );\n};\n\nconst mergeShardAggregate = (totals, shard) => {\n  const mergeGrouping = (tot, shr) => {\n    tot.count += shr.count;\n    for (const aggName in tot) {\n      if (aggName === 'count') continue;\n      const totagg = tot[aggName];\n      const shragg = shr[aggName];\n      totagg.sum += shragg.sum;\n      totagg.max = totagg.max > shragg.max\n        ? totagg.max\n        : shragg.max;\n      totagg.min = totagg.min < shragg.min\n        ? totagg.min\n        : shragg.min;\n      totagg.mean = totagg.sum / tot.count;\n    }\n    return tot;\n  };\n\n  for (const aggGroupDef in totals) {\n    for (const grouping in shard[aggGroupDef]) {\n      const groupingTotal = totals[aggGroupDef][grouping];\n      totals[aggGroupDef][grouping] = isUndefined(groupingTotal)\n        ? shard[aggGroupDef][grouping]\n        : mergeGrouping(\n          totals[aggGroupDef][grouping],\n          shard[aggGroupDef][grouping],\n        );\n    }\n  }\n\n  return totals;\n};\n\nconst getAggregates = async (hierarchy, datastore, index, indexedDataKey) => {\n  const aggregateResult = {};\n  const doRead = iterateIndex(\n        async item => {\n      applyItemToAggregateResult(\n        index, aggregateResult, item,\n      );\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => aggregateResult\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\n\nconst applyItemToAggregateResult = (indexNode, result, item) => {\n  const getInitialAggregateResult = () => ({\n    sum: 0, mean: null, max: null, min: null,\n  });\n\n  const applyAggregateResult = (agg, existing, count) => {\n    const value = compileCode(agg.aggregatedValue)({ record: item });\n\n    if (!isNumber(value)) return existing;\n\n    existing.sum += value;\n    existing.max = value > existing.max || existing.max === null\n      ? value\n      : existing.max;\n    existing.min = value < existing.min || existing.min === null\n      ? value\n      : existing.min;\n    existing.mean = existing.sum / count;\n    return existing;\n  };\n\n  for (const aggGroup of indexNode.aggregateGroups) {\n    if (!has(aggGroup.name)(result)) {\n      result[aggGroup.name] = {};\n    }\n\n    const thisGroupResult = result[aggGroup.name];\n\n    if (isNonEmptyString(aggGroup.condition)) {\n      if (!compileExpression(aggGroup.condition)({ record: item })) {\n        continue;\n      }\n    }\n\n    let group = isNonEmptyString(aggGroup.groupBy)\n      ? compileCode(aggGroup.groupBy)({ record: item })\n      : 'all';\n    if (!isNonEmptyString(group)) {\n      group = '(none)';\n    }\n\n    if (!has(group)(thisGroupResult)) {\n      thisGroupResult[group] = { count: 0 };\n      for (const agg of aggGroup.aggregates) {\n        thisGroupResult[group][agg.name] = getInitialAggregateResult();\n      }\n    }\n\n    thisGroupResult[group].count++;\n\n    for (const agg of aggGroup.aggregates) {\n      const existingValues = thisGroupResult[group][agg.name];\n      thisGroupResult[group][agg.name] = applyAggregateResult(\n        agg, existingValues,\n        thisGroupResult[group].count,\n      );\n    }\n  }\n};\n","import { buildIndex } from './buildIndex';\nimport { listItems } from './listItems';\nimport { aggregates } from './aggregates';\n\nexport const getIndexApi = app => ({\n  listItems: listItems(app),\n  buildIndex: buildIndex(app),\n  aggregates: aggregates(app),\n});\n\nexport default getIndexApi;\n","import { each, find } from 'lodash';\nimport { map, max, constant } from 'lodash/fp';\nimport {\n  switchCase, defaultCase, joinKey,\n  $, isNothing, isSomething,\n} from '../common';\nimport {\n  isIndex, isRoot, isSingleRecord, isCollectionRecord,\n  isRecord, isaggregateGroup,\n  getFlattenedHierarchy,\n} from './hierarchy';\nimport { all } from '../types';\nimport { BadRequestError } from '../common/errors';\n\nexport const createNodeErrors = {\n  indexCannotBeParent: 'Index template cannot be a parent',\n  allNonRootNodesMustHaveParent: 'Only the root node may have no parent',\n  indexParentMustBeRecordOrRoot: 'An index may only have a record or root as a parent',\n  aggregateParentMustBeAnIndex: 'aggregateGroup parent must be an index',\n};\n\nconst pathRegxMaker = node => () => node.nodeKey().replace(/{id}/g, '[a-zA-Z0-9_-]+');\n\nconst nodeKeyMaker = node => () => switchCase(\n\n  [n => isRecord(n) && !isSingleRecord(n),\n    n => joinKey(\n      node.parent().nodeKey(),\n      node.collectionName,\n      `${n.nodeId}-{id}`,\n    )],\n\n  [isRoot,\n    constant('/')],\n\n  [defaultCase,\n    n => joinKey(node.parent().nodeKey(), n.name)],\n\n)(node);\n\n\nconst validate = parent => (node) => {\n  if (isIndex(node)\n        && isSomething(parent)\n        && !isRoot(parent)\n        && !isRecord(parent)) {\n    throw new BadRequestError(createNodeErrors.indexParentMustBeRecordOrRoot);\n  }\n\n  if (isaggregateGroup(node)\n        && isSomething(parent)\n        && !isIndex(parent)) {\n    throw new BadRequestError(createNodeErrors.aggregateParentMustBeAnIndex);\n  }\n\n  if (isNothing(parent) && !isRoot(node)) { throw new BadRequestError(createNodeErrors.allNonRootNodesMustHaveParent); }\n\n  return node;\n};\n\nconst construct = parent => (node) => {\n  node.nodeKey = nodeKeyMaker(node);\n  node.pathRegx = pathRegxMaker(node);\n  node.parent = constant(parent);\n  node.isRoot = () => isNothing(parent)\n                        && node.name === 'root'\n                        && node.type === 'root';\n  if (isCollectionRecord(node)) {\n    node.collectionNodeKey = () => joinKey(\n      parent.nodeKey(), node.collectionName,\n    );\n    node.collectionPathRegx = () => joinKey(\n      parent.pathRegx(), node.collectionName,\n    );\n  }\n  return node;\n};\n\nconst addToParent = (obj) => {\n  const parent = obj.parent();\n  if (isSomething(parent)) {\n    if (isIndex(obj))\n    // Q: why are indexes not children ?\n    // A: because they cannot have children of their own.\n    { \n      parent.indexes.push(obj); \n    } \n    else if (isaggregateGroup(obj)) \n    { \n      parent.aggregateGroups.push(obj); \n    } else { \n      parent.children.push(obj); \n    }\n\n    if (isRecord(obj)) {\n      const defaultIndex = find(\n        parent.indexes,\n        i => i.name === `${parent.name}_index`,\n      );\n      if (defaultIndex) {\n        defaultIndex.allowedRecordNodeIds.push(obj.nodeId);\n      }\n    }\n  }\n  return obj;\n};\n\nexport const constructNode = (parent, obj) => $(obj, [\n  construct(parent),\n  validate(parent),\n  addToParent,\n]);\n\nconst getNodeId = (parentNode) => {\n  // this case is handled better elsewhere\n  if (!parentNode) return null;\n  const findRoot = n => (isRoot(n) ? n : findRoot(n.parent()));\n  const root = findRoot(parentNode);\n\n  return ($(root, [\n    getFlattenedHierarchy,\n    map(n => n.nodeId),\n    max]) + 1);\n};\n\nexport const constructHierarchy = (node, parent) => {\n  construct(parent)(node);\n  if (node.indexes) {\n    each(node.indexes,\n      child => constructHierarchy(child, node));\n  }\n  if (node.aggregateGroups) {\n    each(node.aggregateGroups,\n      child => constructHierarchy(child, node));\n  }\n  if (node.children && node.children.length > 0) {\n    each(node.children,\n      child => constructHierarchy(child, node));\n  }\n  if (node.fields) {\n    each(node.fields,\n      f => each(f.typeOptions, (val, key) => {\n        const def = all[f.type].optionDefinitions[key];\n        if (!def) {\n          // unknown typeOption\n          delete f.typeOptions[key];\n        } else {\n          f.typeOptions[key] = def.parse(val);\n        }\n      }));\n  }\n  return node;\n};\n\n\nexport const getNewRootLevel = () => construct()({\n  name: 'root',\n  type: 'root',\n  children: [],\n  pathMaps: [],\n  indexes: [],\n  nodeId: 0,\n});\n\nconst _getNewRecordTemplate = (parent, name, createDefaultIndex, isSingle) => {\n  const node = constructNode(parent, {\n    name,\n    type: 'record',\n    fields: [],\n    children: [],\n    validationRules: [],\n    nodeId: getNodeId(parent),\n    indexes: [],\n    estimatedRecordCount: isRecord(parent) ? 500 : 1000000,\n    collectionName: '',\n    isSingle,\n  });\n\n  if (createDefaultIndex) {\n    const defaultIndex = getNewIndexTemplate(parent);\n    defaultIndex.name = `${name}_index`;\n    defaultIndex.allowedRecordNodeIds.push(node.nodeId);\n  }\n\n  return node;\n};\n\nexport const getNewRecordTemplate = (parent, name = '', createDefaultIndex = true) => _getNewRecordTemplate(parent, name, createDefaultIndex, false);\n\nexport const getNewSingleRecordTemplate = parent => _getNewRecordTemplate(parent, '', false, true);\n\nexport const getNewIndexTemplate = (parent, type = 'ancestor') => constructNode(parent, {\n  name: '',\n  type: 'index',\n  map: 'return {...record};',\n  filter: '',\n  indexType: type,\n  getShardName: '',\n  getSortKey: 'record.id',\n  aggregateGroups: [],\n  allowedRecordNodeIds: [],\n  nodeId: getNodeId(parent),\n});\n\nexport const getNewAggregateGroupTemplate = index => constructNode(index, {\n  name: '',\n  type: 'aggregateGroup',\n  groupBy: '',\n  aggregates: [],\n  condition: '',\n  nodeId: getNodeId(index),\n});\n\nexport const getNewAggregateTemplate = (set) => {\n  const aggregatedValue = {\n    name: '',\n    aggregatedValue: '',\n  };\n  set.aggregates.push(aggregatedValue);\n  return aggregatedValue;\n};\n\nexport default {\n  getNewRootLevel,\n  getNewRecordTemplate,\n  getNewIndexTemplate,\n  createNodeErrors,\n  constructHierarchy,\n  getNewAggregateGroupTemplate,\n  getNewAggregateTemplate,\n};\n","import {\n  some, map, filter, keys, includes,\n  countBy, flatten,\n} from 'lodash/fp';\nimport {\n  isSomething, $,\n  isNonEmptyString,\n  isNothingOrEmpty,\n  isNothing,\n} from '../common';\nimport { all, getDefaultOptions } from '../types';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { BadRequestError } from '../common/errors';\n\nexport const fieldErrors = {\n  AddFieldValidationFailed: 'Add field validation: ',\n};\n\nexport const allowedTypes = () => keys(all);\n\nexport const getNewField = type => ({\n  name: '', // how field is referenced internally\n  type,\n  typeOptions: getDefaultOptions(type),\n  label: '', // how field is displayed\n  getInitialValue: 'default', // function that gets value when initially created\n  getUndefinedValue: 'default', // function that gets value when field undefined on record\n});\n\nconst fieldRules = allFields => [\n  makerule('name', 'field name is not set',\n    f => isNonEmptyString(f.name)),\n  makerule('type', 'field type is not set',\n    f => isNonEmptyString(f.type)),\n  makerule('label', 'field label is not set',\n    f => isNonEmptyString(f.label)),\n  makerule('getInitialValue', 'getInitialValue function is not set',\n    f => isNonEmptyString(f.getInitialValue)),\n  makerule('getUndefinedValue', 'getUndefinedValue function is not set',\n    f => isNonEmptyString(f.getUndefinedValue)),\n  makerule('name', 'field name is duplicated',\n    f => isNothingOrEmpty(f.name)\n             || countBy('name')(allFields)[f.name] === 1),\n  makerule('type', 'type is unknown',\n    f => isNothingOrEmpty(f.type)\n             || some(t => f.type === t)(allowedTypes())),\n];\n\nconst typeOptionsRules = (field) => {\n  const type = all[field.type];\n  if (isNothing(type)) return [];\n\n  const def = optName => type.optionDefinitions[optName];\n\n  return $(field.typeOptions, [\n    keys,\n    filter(o => isSomething(def(o))\n                    && isSomething(def(o).isValid)),\n    map(o => makerule(\n      `typeOptions.${o}`,\n      `${def(o).requirementDescription}`,\n      field => def(o).isValid(field.typeOptions[o]),\n    )),\n  ]);\n};\n\nexport const validateField = allFields => (field) => {\n  const everySingleField = includes(field)(allFields) ? allFields : [...allFields, field];\n  return applyRuleSet([...fieldRules(everySingleField), ...typeOptionsRules(field)])(field);\n};\n\nexport const validateAllFields = recordNode => $(recordNode.fields, [\n  map(validateField(recordNode.fields)),\n  flatten,\n]);\n\nexport const addField = (recordTemplate, field) => {\n  if (isNothingOrEmpty(field.label)) {\n    field.label = field.name;\n  }\n  const validationMessages = validateField([...recordTemplate.fields, field])(field);\n  if (validationMessages.length > 0) {\n    const errors = map(m => m.error)(validationMessages);\n    throw new BadRequestError(`${fieldErrors.AddFieldValidationFailed} ${errors.join(', ')}`);\n  }\n  recordTemplate.fields.push(field);\n};\n","import { isNumber, isBoolean, defaultCase } from 'lodash/fp';\nimport { switchCase } from '../common';\n\nexport const getNewRecordValidationRule = (invalidFields,\n  messageWhenInvalid,\n  expressionWhenValid) => ({\n  invalidFields, messageWhenInvalid, expressionWhenValid,\n});\n\nconst getStaticValue = switchCase(\n  [isNumber, v => v.toString()],\n  [isBoolean, v => v.toString()],\n  [defaultCase, v => `'${v}'`],\n);\n\nexport const commonRecordValidationRules = ({\n\n  fieldNotEmpty: fieldName => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} is empty`,\n    `!_.isEmpty(record['${fieldName}'])`,\n  ),\n\n  fieldBetween: (fieldName, min, max) => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} must be between ${min.toString()} and ${max.toString()}`,\n    `record['${fieldName}'] >= ${getStaticValue(min)} &&  record['${fieldName}'] <= ${getStaticValue(max)} `,\n  ),\n\n  fieldGreaterThan: (fieldName, min, max) => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} must be greater than ${min.toString()} and ${max.toString()}`,\n    `record['${fieldName}'] >= ${getStaticValue(min)}  `,\n  ),\n});\n\nexport const addRecordValidationRule = recordNode => rule => recordNode.validationRules.push(rule);\n","\nexport const createTrigger = () => ({\n  actionName: '',\n  eventName: '',\n  // function, has access to event context,\n  // returns object that is used as parameter to action\n  // only used if triggered by event\n  optionsCreator: '',\n  // action runs if true,\n  // has access to event context\n  condition: '',\n});\n\nexport const createAction = () => ({\n  name: '',\n  behaviourSource: '',\n  // name of function in actionSource\n  behaviourName: '',\n  // parameter passed into behaviour.\n  // any other parms passed at runtime e.g.\n  // by trigger, or manually, will be merged into this\n  initialOptions: {},\n});\n","import { flatten, map, isEmpty } from 'lodash/fp';\nimport { compileCode } from '@nx-js/compiler-util';\nimport {\n  isNonEmptyString, \n  executesWithoutException, $, \n} from '../common';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\n\nconst aggregateRules = [\n  makerule('name', 'choose a name for the aggregate',\n    a => isNonEmptyString(a.name)),\n  makerule('aggregatedValue', 'aggregatedValue does not compile',\n    a => isEmpty(a.aggregatedValue)\n            || executesWithoutException(\n              () => compileCode(a.aggregatedValue),\n            )),\n];\n\nexport const validateAggregate = aggregate => applyRuleSet(aggregateRules)(aggregate);\n\nexport const validateAllAggregates = all => $(all, [\n  map(validateAggregate),\n  flatten,\n]);\n","import {\n  filter, union, constant,\n  map, flatten, every, uniqBy,\n  some, includes, isEmpty, has\n} from 'lodash/fp';\nimport { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  $, isSomething, switchCase,\n  anyTrue, isNonEmptyArray, executesWithoutException,\n  isNonEmptyString, defaultCase,\n} from '../common';\nimport {\n  isRecord, isRoot, isaggregateGroup,\n  isIndex, getFlattenedHierarchy,\n} from './hierarchy';\nimport { eventsList } from '../common/events';\nimport { validateAllFields } from './fields';\nimport {\n  applyRuleSet, makerule, stringNotEmpty,\n  validationError,\n} from '../common/validationCommon';\nimport { indexRuleSet } from './indexes';\nimport { validateAllAggregates } from './validateAggregate';\n\nexport const ruleSet = (...sets) => constant(flatten([...sets]));\n\nconst commonRules = [\n  makerule('name', 'node name is not set',\n    node => stringNotEmpty(node.name)),\n  makerule('type', 'node type not recognised',\n    anyTrue(isRecord, isRoot, isIndex, isaggregateGroup)),\n];\n\nconst recordRules = [\n  makerule('fields', 'no fields have been added to the record',\n    node => isNonEmptyArray(node.fields)),\n  makerule('validationRules', \"validation rule is missing a 'messageWhenValid' member\",\n    node => every(r => has('messageWhenInvalid')(r))(node.validationRules)),\n  makerule('validationRules', \"validation rule is missing a 'expressionWhenValid' member\",\n    node => every(r => has('expressionWhenValid')(r))(node.validationRules)),\n];\n\n\nconst aggregateGroupRules = [\n  makerule('condition', 'condition does not compile',\n    a => isEmpty(a.condition)\n             || executesWithoutException(\n               () => compileExpression(a.condition),\n             )),\n];\n\nconst getRuleSet = node => switchCase(\n\n  [isRecord, ruleSet(\n    commonRules,\n    recordRules,\n  )],\n\n  [isIndex, ruleSet(\n    commonRules,\n    indexRuleSet,\n  )],\n\n  [isaggregateGroup, ruleSet(\n    commonRules,\n    aggregateGroupRules,\n  )],\n\n  [defaultCase, ruleSet(commonRules, [])],\n)(node);\n\nexport const validateNode = node => applyRuleSet(getRuleSet(node))(node);\n\nexport const validateAll = (appHierarchy) => {\n  const flattened = getFlattenedHierarchy(\n    appHierarchy,\n  );\n\n  const duplicateNameRule = makerule(\n    'name', 'node names must be unique under shared parent',\n    n => filter(f => f.parent() === n.parent()\n                          && f.name === n.name)(flattened).length === 1,\n  );\n\n  const duplicateNodeKeyErrors = $(flattened, [\n    map(n => applyRuleSet([duplicateNameRule])(n)),\n    filter(isSomething),\n    flatten,\n  ]);\n\n  const fieldErrors = $(flattened, [\n    filter(isRecord),\n    map(validateAllFields),\n    flatten,\n  ]);\n\n  const aggregateErrors = $(flattened, [\n    filter(isaggregateGroup),\n    map(s => validateAllAggregates(\n      s.aggregates,\n    )),\n    flatten,\n  ]);\n\n  return $(flattened, [\n    map(validateNode),\n    flatten,\n    union(duplicateNodeKeyErrors),\n    union(fieldErrors),\n    union(aggregateErrors),\n  ]);\n};\n\nconst actionRules = [\n  makerule('name', 'action must have a name',\n    a => isNonEmptyString(a.name)),\n  makerule('behaviourName', 'must supply a behaviour name to the action',\n    a => isNonEmptyString(a.behaviourName)),\n  makerule('behaviourSource', 'must supply a behaviour source for the action',\n    a => isNonEmptyString(a.behaviourSource)),\n];\n\nconst duplicateActionRule = makerule('', 'action name must be unique', () => {});\n\nconst validateAction = action => applyRuleSet(actionRules)(action);\n\n\nexport const validateActions = (allActions) => {\n  const duplicateActions = $(allActions, [\n    filter(a => filter(a2 => a2.name === a.name)(allActions).length > 1),\n    map(a => validationError(duplicateActionRule, a)),\n  ]);\n\n  const errors = $(allActions, [\n    map(validateAction),\n    flatten,\n    union(duplicateActions),\n    uniqBy('name'),\n  ]);\n\n  return errors;\n};\n\nconst triggerRules = actions => ([\n  makerule('actionName', 'must specify an action',\n    t => isNonEmptyString(t.actionName)),\n  makerule('eventName', 'must specify and event',\n    t => isNonEmptyString(t.eventName)),\n  makerule('actionName', 'specified action not supplied',\n    t => !t.actionName\n             || some(a => a.name === t.actionName)(actions)),\n  makerule('eventName', 'invalid Event Name',\n    t => !t.eventName\n             || includes(t.eventName)(eventsList)),\n  makerule('optionsCreator', 'Options Creator does not compile - check your expression',\n    (t) => {\n      if (!t.optionsCreator) return true;\n      try {\n        compileCode(t.optionsCreator);\n        return true;\n      } catch (_) { return false; }\n    }),\n  makerule('condition', 'Trigger condition does not compile - check your expression',\n    (t) => {\n      if (!t.condition) return true;\n      try {\n        compileExpression(t.condition);\n        return true;\n      } catch (_) { return false; }\n    }),\n]);\n\nexport const validateTrigger = (trigger, allActions) => {\n  const errors = applyRuleSet(triggerRules(allActions))(trigger);\n\n  return errors;\n};\n\nexport const validateTriggers = (triggers, allActions) => $(triggers, [\n  map(t => validateTrigger(t, allActions)),\n  flatten,\n]);\n","import { appDefinitionFile } from '../common';\nimport { constructHierarchy } from './createNodes';\n\nexport const getApplicationDefinition = datastore => async () => {\n  const exists = await datastore.exists(appDefinitionFile);\n\n  if (!exists) throw new Error('Application definition does not exist');\n\n  const appDefinition = await datastore.loadJson(appDefinitionFile);\n  appDefinition.hierarchy = constructHierarchy(\n    appDefinition.hierarchy,\n  );\n  return appDefinition;\n};\n","import { join } from 'lodash';\nimport { permission } from '../authApi/permissions';\nimport { appDefinitionFile } from '../common';\nimport { validateAll } from './validate';\nimport { apiWrapper } from '../common/apiWrapper';\nimport { events } from '../common/events';\n\nexport const saveApplicationHierarchy = app => async hierarchy => apiWrapper(\n  app,\n  events.templateApi.saveApplicationHierarchy,\n  permission.writeTemplates.isAuthorized,\n  { hierarchy },\n  _saveApplicationHierarchy, app.datastore, hierarchy,\n);\n\n\nexport const _saveApplicationHierarchy = async (datastore, hierarchy) => {\n  const validationErrors = await validateAll(hierarchy);\n  if (validationErrors.length > 0) {\n    throw new Error(`Hierarchy is invalid: ${join(\n      validationErrors.map(e => `${e.item.nodeKey ? e.item.nodeKey() : ''} : ${e.error}`),\n      ',',\n    )}`);\n  }\n\n  if (await datastore.exists(appDefinitionFile)) {\n    const appDefinition = await datastore.loadJson(appDefinitionFile);\n    appDefinition.hierarchy = hierarchy;\n    await datastore.updateJson(appDefinitionFile, appDefinition);\n  } else {\n    await datastore.createFolder('/.config');\n    const appDefinition = { actions: [], triggers: [], hierarchy };\n    await datastore.createJson(appDefinitionFile, appDefinition);\n  }\n};\n","import { join } from 'lodash';\nimport { map } from 'lodash/fp';\nimport { appDefinitionFile } from '../common';\nimport { validateTriggers, validateActions } from './validate';\nimport { apiWrapper } from '../common/apiWrapper';\nimport { events } from '../common/events';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\n\nexport const saveActionsAndTriggers = app => async (actions, triggers) => apiWrapper(\n  app,\n  events.templateApi.saveActionsAndTriggers,\n  permission.writeTemplates.isAuthorized,\n  { actions, triggers },\n  _saveActionsAndTriggers, app.datastore, actions, triggers,\n);\n\nexport const _saveActionsAndTriggers = async (datastore, actions, triggers) => {\n  if (await datastore.exists(appDefinitionFile)) {\n    const appDefinition = await datastore.loadJson(appDefinitionFile);\n    appDefinition.actions = actions;\n    appDefinition.triggers = triggers;\n\n    const actionValidErrs = map(e => e.error)(validateActions(actions));\n\n    if (actionValidErrs.length > 0) {\n      throw new BadRequestError(`Actions are invalid: ${join(actionValidErrs, ', ')}`);\n    }\n\n    const triggerValidErrs = map(e => e.error)(validateTriggers(triggers, actions));\n\n    if (triggerValidErrs.length > 0) {\n      throw new BadRequestError(`Triggers are invalid: ${join(triggerValidErrs, ', ')}`);\n    }\n\n    await datastore.updateJson(appDefinitionFile, appDefinition);\n  } else {\n    throw new BadRequestError('Cannot save actions: Application definition does not exist');\n  }\n};\n","\nexport const getBehaviourSources = async (datastore) => {\n    await datastore.loadFile('/.config/behaviourSources.js');\n};\n","import {\n  getNewRootLevel,\n  getNewRecordTemplate, getNewIndexTemplate,\n  createNodeErrors, constructHierarchy,\n  getNewAggregateGroupTemplate, getNewSingleRecordTemplate,\n  getNewAggregateTemplate, constructNode,\n}\n  from './createNodes';\nimport {\n  getNewField, validateField,\n  addField, fieldErrors,\n} from './fields';\nimport {\n  getNewRecordValidationRule, commonRecordValidationRules,\n  addRecordValidationRule,\n} from './recordValidationRules';\nimport { createAction, createTrigger } from './createActions';\nimport {\n  validateTriggers, validateTrigger, validateNode,\n  validateActions, validateAll,\n} from './validate';\nimport { getApplicationDefinition } from './getApplicationDefinition';\nimport { saveApplicationHierarchy } from './saveApplicationHierarchy';\nimport { saveActionsAndTriggers } from './saveActionsAndTriggers';\nimport { all } from '../types';\nimport { getBehaviourSources } from \"./getBehaviourSources\";\n\nconst api = app => ({\n\n  getApplicationDefinition: getApplicationDefinition(app.datastore),\n  saveApplicationHierarchy: saveApplicationHierarchy(app),\n  saveActionsAndTriggers: saveActionsAndTriggers(app),\n  getBehaviourSources: () => getBehaviourSources(app.datastore),\n  getNewRootLevel,\n  constructNode,\n  getNewIndexTemplate,\n  getNewRecordTemplate,\n  getNewField,\n  validateField,\n  addField,\n  fieldErrors,\n  getNewRecordValidationRule,\n  commonRecordValidationRules,\n  addRecordValidationRule,\n  createAction,\n  createTrigger,\n  validateActions,\n  validateTrigger,\n  getNewAggregateGroupTemplate,\n  getNewAggregateTemplate,\n  constructHierarchy,\n  getNewSingleRecordTemplate,\n  allTypes: all,\n  validateNode,\n  validateAll,\n  validateTriggers,\n});\n\n\nexport const getTemplateApi = app => api(app);\n\nexport const errors = createNodeErrors;\n\nexport default getTemplateApi;\n","import { map } from 'lodash/fp';\nimport {\n  USERS_LIST_FILE,\n  stripUserOfSensitiveStuff,\n} from './authCommon';\nimport { $, apiWrapper, events } from '../common';\nimport { permission } from './permissions';\n\nexport const getUsers = app => async () => apiWrapper(\n  app,\n  events.authApi.getUsers,\n  permission.listUsers.isAuthorized,\n  {},\n  _getUsers, app,\n);\n\nexport const _getUsers = async app => $(await app.datastore.loadJson(USERS_LIST_FILE), [\n  map(stripUserOfSensitiveStuff),\n]);\n","import { ACCESS_LEVELS_FILE } from './authCommon';\nimport { apiWrapper, events } from '../common';\nimport { permission } from './permissions';\n\nexport const loadAccessLevels = app => async () => apiWrapper(\n  app,\n  events.authApi.loadAccessLevels,\n  permission.listAccessLevels.isAuthorized,\n  {},\n  _loadAccessLevels, app,\n);\n\nexport const _loadAccessLevels = async app => await app.datastore.loadJson(ACCESS_LEVELS_FILE);\n","import {\n  find, filter, some,\n  map, flatten,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { _getUsers } from './getUsers';\nimport {\n  getUserByName, userAuthFile,\n  parseTemporaryCode,\n} from './authCommon';\nimport { _loadAccessLevels } from './loadAccessLevels';\nimport {\n  isNothingOrEmpty, $, apiWrapper, events,\n} from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nconst dummyHash = '$argon2i$v=19$m=4096,t=3,p=1$UZRo409UYBGjHJS3CV6Uxw$rU84qUqPeORFzKYmYY0ceBLDaPO+JWSH4PfNiKXfIKk';\n\nexport const authenticate = app => async (username, password) => apiWrapper(\n  app,\n  events.authApi.authenticate,\n  alwaysAuthorized,\n  { username, password },\n  _authenticate, app, username, password,\n);\n\nexport const _authenticate = async (app, username, password) => {\n  if (isNothingOrEmpty(username) || isNothingOrEmpty(password)) { return null; }\n\n  const allUsers = await _getUsers(app);\n  let user = getUserByName(\n    allUsers,\n    username,\n  );\n\n  const notAUser = 'not-a-user';\n  // continue with non-user - so time to verify remains consistent\n  // with verification of a valid user\n  if (!user || !user.enabled) { user = notAUser; }\n\n  let userAuth;\n  try {\n    userAuth = await app.datastore.loadJson(\n      userAuthFile(username),\n    );\n  } catch (_) {\n    userAuth = { accessLevels: [], passwordHash: dummyHash };\n  }\n\n  const permissions = await buildUserPermissions(app, user.accessLevels);\n\n  const verified = await app.crypto.verify(\n    userAuth.passwordHash,\n    password,\n  );\n\n  if (user === notAUser) { return null; }\n\n  return verified\n    ? {\n      ...user, permissions, temp: false, isUser: true,\n    }\n    : null;\n};\n\nexport const authenticateTemporaryAccess = app => async (tempAccessCode) => {\n  if (isNothingOrEmpty(tempAccessCode)) { return null; }\n\n  const temp = parseTemporaryCode(tempAccessCode);\n  let user = $(await _getUsers(app), [\n    find(u => u.temporaryAccessId === temp.id),\n  ]);\n\n  const notAUser = 'not-a-user';\n  if (!user || !user.enabled) { user = notAUser; }\n\n  let userAuth;\n  try {\n    userAuth = await app.datastore.loadJson(\n      userAuthFile(user.name),\n    );\n  } catch (e) {\n    userAuth = {\n      temporaryAccessHash: dummyHash,\n      temporaryAccessExpiryEpoch: (await app.getEpochTime() + 10000),\n    };\n  }\n\n  if (userAuth.temporaryAccessExpiryEpoch < await app.getEpochTime()) { user = notAUser; }\n\n  const tempCode = !temp.code ? generate() : temp.code;\n  const verified = await app.crypto.verify(\n    userAuth.temporaryAccessHash,\n    tempCode,\n  );\n\n  if (user === notAUser) { return null; }\n\n  return verified\n    ? {\n      ...user,\n      permissions: [],\n      temp: true,\n      isUser: true,\n    }\n    : null;\n};\n\nexport const buildUserPermissions = async (app, userAccessLevels) => {\n  const allAccessLevels = await _loadAccessLevels(app);\n\n  return $(allAccessLevels.levels, [\n    filter(l => some(ua => l.name === ua)(userAccessLevels)),\n    map(l => l.permissions),\n    flatten,\n  ]);\n};\n","import { generate } from 'shortid';\nimport {\n  tempCodeExpiryLength, USERS_LOCK_FILE,\n  USERS_LIST_FILE, userAuthFile,\n  getUserByName,\n} from './authCommon';\nimport {\n  getLock, isNolock,\n  releaseLock,\n} from '../common/lock';\nimport { apiWrapper, events } from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nexport const createTemporaryAccess = app => async userName => apiWrapper(\n  app,\n  events.authApi.createTemporaryAccess,\n  alwaysAuthorized,\n  { userName },\n  _createTemporaryAccess, app, userName,\n);\n\nexport const _createTemporaryAccess = async (app, userName) => {\n  const tempCode = await getTemporaryCode(app);\n\n  const lock = await getLock(\n    app, USERS_LOCK_FILE, 1000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Unable to create temporary access, could not get lock - try again'); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n\n    const user = getUserByName(users, userName);\n    user.temporaryAccessId = tempCode.temporaryAccessId;\n\n    await app.datastore.updateJson(\n      USERS_LIST_FILE,\n      users,\n    );\n  } finally {\n    await releaseLock(app, lock);\n  }\n\n  const userAuth = await app.datastore.loadJson(\n    userAuthFile(userName),\n  );\n  userAuth.temporaryAccessHash = tempCode.temporaryAccessHash;\n\n  userAuth.temporaryAccessExpiryEpoch = tempCode.temporaryAccessExpiryEpoch;\n\n  await app.datastore.updateJson(\n    userAuthFile(userName),\n    userAuth,\n  );\n\n  return tempCode.tempCode;\n};\n\nexport const getTemporaryCode = async (app) => {\n  const tempCode = generate()\n        + generate()\n        + generate()\n        + generate();\n\n  const tempId = generate();\n\n  return {\n    temporaryAccessHash: await app.crypto.hash(\n      tempCode,\n    ),\n    temporaryAccessExpiryEpoch:\n            (await app.getEpochTime()) + tempCodeExpiryLength,\n    tempCode: `tmp:${tempId}:${tempCode}`,\n    temporaryAccessId: tempId,\n  };\n};\n\nexport const looksLikeTemporaryCode = code => code.startsWith('tmp:');\n","import {\n  map, uniqWith,\n  flatten, filter,\n} from 'lodash/fp';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport {\n  $, insensitiveEquals, apiWrapper, events,\n  isNonEmptyString, all,\n} from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nconst userRules = allUsers => [\n  makerule('name', 'username must be set',\n    u => isNonEmptyString(u.name)),\n  makerule('accessLevels', 'user must have at least one access level',\n    u => u.accessLevels.length > 0),\n  makerule('name', 'username must be unique',\n    u => filter(u2 => insensitiveEquals(u2.name, u.name))(allUsers).length === 1),\n  makerule('accessLevels', 'access levels must only contain stings',\n    u => all(isNonEmptyString)(u.accessLevels)),\n];\n\nexport const validateUser = () => (allusers, user) => applyRuleSet(userRules(allusers))(user);\n\nexport const validateUsers = app => allUsers => apiWrapper(\n  app,\n  events.authApi.validateUsers,\n  alwaysAuthorized,\n  { allUsers },\n  _validateUsers, app, allUsers,\n);\n\nexport const _validateUsers = (app, allUsers) => $(allUsers, [\n  map(l => validateUser(app)(allUsers, l)),\n  flatten,\n  uniqWith((x, y) => x.field === y.field\n                        && x.item === y.item\n                        && x.error === y.error),\n]);\n","import { apiWrapperSync, events } from '../common';\nimport { permission } from './permissions';\n\nexport const getNewUser = app => () => apiWrapperSync(\n  app,\n  events.authApi.getNewUser,\n  permission.createUser.isAuthorized,\n  {},\n  _getNewUser, app,\n);\n\nexport const _getNewUser = () => ({\n  name: '',\n  accessLevels: [],\n  enabled: true,\n  temporaryAccessId: '',\n});\n\nexport const getNewUserAuth = app => () => apiWrapperSync(\n  app,\n  events.authApi.getNewUserAuth,\n  permission.createUser.isAuthorized,\n  {},\n  _getNewUserAuth, app,\n);\n\nexport const _getNewUserAuth = () => ({\n  passwordHash: '',\n  temporaryAccessHash: '',\n  temporaryAccessExpiryEpoch: 0,\n});\n","import { find } from 'lodash/fp';\nimport { userAuthFile, parseTemporaryCode } from './authCommon';\nimport {\n  isSomething, $, apiWrapper, apiWrapperSync, events,\n} from '../common';\nimport { _getUsers } from './getUsers';\nimport { alwaysAuthorized } from './permissions';\n\nexport const isValidPassword = app => password => apiWrapperSync(\n  app,\n  events.authApi.isValidPassword,\n  alwaysAuthorized,\n  { password },\n  _isValidPassword, app, password,\n);\n\nexport const _isValidPassword = (app, password) => scorePassword(password).score > 30;\n\nexport const changeMyPassword = app => async (currentPw, newpassword) => apiWrapper(\n  app,\n  events.authApi.changeMyPassword,\n  alwaysAuthorized,\n  { currentPw, newpassword },\n  _changeMyPassword, app, currentPw, newpassword,\n);\n\nexport const _changeMyPassword = async (app, currentPw, newpassword) => {\n  const existingAuth = await app.datastore.loadJson(\n    userAuthFile(app.user.name),\n  );\n\n  if (isSomething(existingAuth.passwordHash)) {\n    const verified = await app.crypto.verify(\n      existingAuth.passwordHash,\n      currentPw,\n    );\n\n    if (verified) {\n      await await doSet(\n        app, existingAuth,\n        app.user.name, newpassword,\n      );\n      return true;\n    }\n  }\n\n  return false;\n};\n\nexport const setPasswordFromTemporaryCode = app => async (tempCode, newpassword) => apiWrapper(\n  app,\n  events.authApi.setPasswordFromTemporaryCode,\n  alwaysAuthorized,\n  { tempCode, newpassword },\n  _setPasswordFromTemporaryCode, app, tempCode, newpassword,\n);\n\n\nexport const _setPasswordFromTemporaryCode = async (app, tempCode, newpassword) => {\n  const currentTime = await app.getEpochTime();\n\n  const temp = parseTemporaryCode(tempCode);\n\n  const user = $(await _getUsers(app), [\n    find(u => u.temporaryAccessId === temp.id),\n  ]);\n\n  if (!user) { return false; }\n\n  const existingAuth = await app.datastore.loadJson(\n    userAuthFile(user.name),\n  );\n\n  if (isSomething(existingAuth.temporaryAccessHash)\n       && existingAuth.temporaryAccessExpiryEpoch > currentTime) {\n    const verified = await app.crypto.verify(\n      existingAuth.temporaryAccessHash,\n      temp.code,\n    );\n\n    if (verified) {\n      await doSet(\n        app, existingAuth,\n        user.name, newpassword,\n      );\n      return true;\n    }\n  }\n\n  return false;\n};\n\nconst doSet = async (app, auth, username, newpassword) => {\n  auth.temporaryAccessHash = '';\n  auth.temporaryAccessExpiryEpoch = 0;\n  auth.passwordHash = await app.crypto.hash(\n    newpassword,\n  );\n  await app.datastore.updateJson(\n    userAuthFile(username),\n    auth,\n  );\n};\n\nexport const scorePassword = app => password => apiWrapperSync(\n  app,\n  events.authApi.scorePassword,\n  alwaysAuthorized,\n  { password },\n  _scorePassword, password,\n);\n\nexport const _scorePassword = (password) => {\n  // from https://stackoverflow.com/questions/948172/password-strength-meter\n  // thank you https://stackoverflow.com/users/46617/tm-lv\n\n  let score = 0;\n  if (!password) { return score; }\n\n  // award every unique letter until 5 repetitions\n  const letters = new Object();\n  for (let i = 0; i < password.length; i++) {\n    letters[password[i]] = (letters[password[i]] || 0) + 1;\n    score += 5.0 / letters[password[i]];\n  }\n\n  // bonus points for mixing it up\n  const variations = {\n    digits: /\\d/.test(password),\n    lower: /[a-z]/.test(password),\n    upper: /[A-Z]/.test(password),\n    nonWords: /\\W/.test(password),\n  };\n\n  let variationCount = 0;\n  for (const check in variations) {\n    variationCount += (variations[check] == true) ? 1 : 0;\n  }\n  score += (variationCount - 1) * 10;\n\n  const strengthText = score > 80\n    ? 'strong'\n    : score > 60\n      ? 'good'\n      : score >= 30\n        ? 'weak'\n        : 'very weak';\n\n  return {\n    score: parseInt(score),\n    strengthText,\n  };\n};\n","import { join, some } from 'lodash/fp';\nimport { validateUser } from './validateUser';\nimport { getNewUserAuth } from './getNewUser';\nimport {\n  getLock, isNolock, releaseLock, apiWrapper, events,\n  insensitiveEquals, isNonEmptyString,\n} from '../common';\nimport {\n  USERS_LOCK_FILE, stripUserOfSensitiveStuff,\n  USERS_LIST_FILE, userAuthFile,\n} from './authCommon';\nimport { getTemporaryCode } from './createTemporaryAccess';\nimport { isValidPassword } from './setPassword';\nimport { permission } from './permissions';\nimport { BadRequestError } from '../common/errors';\n\nexport const createUser = app => async (user, password = null) => apiWrapper(\n  app,\n  events.authApi.createUser,\n  permission.createUser.isAuthorized,\n  { user, password },\n  _createUser, app, user, password,\n);\n\nexport const _createUser = async (app, user, password = null) => {\n  const lock = await getLock(\n    app, USERS_LOCK_FILE, 1000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Unable to create user, could not get lock - try again'); }\n\n  const users = await app.datastore.loadJson(USERS_LIST_FILE);\n\n  const userErrors = validateUser(app)([...users, user], user);\n  if (userErrors.length > 0) { throw new BadRequestError(`User is invalid. ${join('; ')(userErrors)}`); }\n\n  const { auth, tempCode, temporaryAccessId } = await getAccess(\n    app, password,\n  );\n  user.tempCode = tempCode;\n  user.temporaryAccessId = temporaryAccessId;\n\n  if (some(u => insensitiveEquals(u.name, user.name))(users)) { \n    throw new BadRequestError('User already exists'); \n  }\n\n  users.push(\n    stripUserOfSensitiveStuff(user),\n  );\n\n  await app.datastore.updateJson(\n    USERS_LIST_FILE,\n    users,\n  );\n\n  try {\n    await app.datastore.createJson(\n      userAuthFile(user.name),\n      auth,\n    );\n  } catch (_) {\n    await app.datastore.updateJson(\n      userAuthFile(user.name),\n      auth,\n    );\n  }\n\n  await releaseLock(app, lock);\n\n  return user;\n};\n\nconst getAccess = async (app, password) => {\n  const auth = getNewUserAuth(app)();\n\n  if (isNonEmptyString(password)) {\n    if (isValidPassword(password)) {\n      auth.passwordHash = await app.crypto.hash(password);\n      auth.temporaryAccessHash = '';\n      auth.temporaryAccessId = '';\n      auth.temporaryAccessExpiryEpoch = 0;\n      return { auth };\n    }\n    throw new BadRequestError('Password does not meet requirements');\n  } else {\n    const tempAccess = await getTemporaryCode(app);\n    auth.temporaryAccessHash = tempAccess.temporaryAccessHash;\n    auth.temporaryAccessExpiryEpoch = tempAccess.temporaryAccessExpiryEpoch;\n    auth.passwordHash = '';\n    return ({\n      auth,\n      tempCode: tempAccess.tempCode,\n      temporaryAccessId: tempAccess.temporaryAccessId,\n    });\n  }\n};\n","import {\n  getLock,\n  isNolock, releaseLock,\n} from '../common/lock';\nimport { USERS_LOCK_FILE, USERS_LIST_FILE, getUserByName } from './authCommon';\nimport { apiWrapper, events } from '../common';\nimport { permission } from './permissions';\nimport { NotFoundError } from '../common/errors';\n\nexport const enableUser = app => async username => apiWrapper(\n  app,\n  events.authApi.enableUser,\n  permission.enableDisableUser.isAuthorized,\n  { username },\n  _enableUser, app, username,\n);\n\nexport const disableUser = app => async username => apiWrapper(\n  app,\n  events.authApi.disableUser,\n  permission.enableDisableUser.isAuthorized,\n  { username },\n  _disableUser, app, username,\n);\n\nexport const _enableUser = async (app, username) => await toggleUser(app, username, true);\n\nexport const _disableUser = async (app, username) => await toggleUser(app, username, false);\n\nconst toggleUser = async (app, username, enabled) => {\n  const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0);\n\n  const actionName = enabled ? 'enable' : 'disable';\n\n  if (isNolock(lock)) { throw new Error(`Could not ${actionName} user - cannot get lock`); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n    const user = getUserByName(users, username);\n    if (!user) { throw new NotFoundError(`Could not find user to ${actionName}`); }\n\n    if (user.enabled === !enabled) {\n      user.enabled = enabled;\n      await app.datastore.updateJson(USERS_LIST_FILE, users);\n    }\n  } finally {\n    releaseLock(app, lock);\n  }\n};\n","export const getNewAccessLevel = () => () => ({\n  name: '',\n  permissions: [],\n  default:false\n});\n","import {\n  values, includes, map, concat, isEmpty, uniqWith, some,\n  flatten, filter,\n} from 'lodash/fp';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { permissionTypes } from './authCommon';\nimport {\n  $, isSomething, insensitiveEquals,\n  isNonEmptyString, apiWrapperSync, events,\n} from '../common';\nimport { getNode } from '../templateApi/hierarchy';\nimport { alwaysAuthorized } from './permissions';\n\nconst isAllowedType = t => $(permissionTypes, [\n  values,\n  includes(t),\n]);\n\nconst isRecordOrIndexType = t => some(p => p === t)([\n  permissionTypes.CREATE_RECORD,\n  permissionTypes.UPDATE_RECORD,\n  permissionTypes.DELETE_RECORD,\n  permissionTypes.READ_RECORD,\n  permissionTypes.READ_INDEX,\n  permissionTypes.EXECUTE_ACTION,\n]);\n\n\nconst permissionRules = app => ([\n  makerule('type', 'type must be one of allowed types',\n    p => isAllowedType(p.type)),\n  makerule('nodeKey', 'record and index permissions must include a valid nodeKey',\n    p => (!isRecordOrIndexType(p.type))\n             || isSomething(getNode(app.hierarchy, p.nodeKey))),\n]);\n\nconst applyPermissionRules = app => applyRuleSet(permissionRules(app));\n\nconst accessLevelRules = allLevels => ([\n  makerule('name', 'name must be set',\n    l => isNonEmptyString(l.name)),\n  makerule('name', 'access level names must be unique',\n    l => isEmpty(l.name)\n             || filter(a => insensitiveEquals(l.name, a.name))(allLevels).length === 1),\n]);\n\nconst applyLevelRules = allLevels => applyRuleSet(accessLevelRules(allLevels));\n\nexport const validateAccessLevel = app => (allLevels, level) => {\n  const errs = $(level.permissions, [\n    map(applyPermissionRules(app)),\n    flatten,\n    concat(\n      applyLevelRules(allLevels)(level),\n    ),\n  ]);\n\n  return errs;\n};\n\nexport const validateAccessLevels = app => allLevels => apiWrapperSync(\n  app,\n  events.authApi.validateAccessLevels,\n  alwaysAuthorized,\n  { allLevels },\n  _validateAccessLevels, app, allLevels,\n);\n\nexport const _validateAccessLevels = (app, allLevels) => $(allLevels, [\n  map(l => validateAccessLevel(app)(allLevels, l)),\n  flatten,\n  uniqWith((x, y) => x.field === y.field\n                        && x.item === y.item\n                        && x.error === y.error),\n]);\n","import { join, map } from 'lodash/fp';\nimport {\n  getLock, releaseLock, $,\n  isNolock, apiWrapper, events,\n} from '../common';\nimport {\n  ACCESS_LEVELS_LOCK_FILE,\n  ACCESS_LEVELS_FILE,\n} from './authCommon';\nimport { validateAccessLevels } from './validateAccessLevels';\nimport { permission } from './permissions';\n\nexport const saveAccessLevels = app => async accessLevels => apiWrapper(\n  app,\n  events.authApi.saveAccessLevels,\n  permission.writeAccessLevels.isAuthorized,\n  { accessLevels },\n  _saveAccessLevels, app, accessLevels,\n);\n\nexport const _saveAccessLevels = async (app, accessLevels) => {\n  const validationErrors = validateAccessLevels(app)(accessLevels.levels);\n  if (validationErrors.length > 0) {\n    const errs = $(validationErrors, [\n      map(e => e.error),\n      join(', '),\n    ]);\n    throw new Error(\n      `Access Levels Invalid: ${errs}`,\n    );\n  }\n\n  const lock = await getLock(\n    app, ACCESS_LEVELS_LOCK_FILE, 2000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Could not get lock to save access levels'); }\n\n  try {\n    const existing = await app.datastore.loadJson(ACCESS_LEVELS_FILE);\n    if (existing.version !== accessLevels.version) { throw new Error('Access levels have already been updated, since you loaded'); }\n\n    accessLevels.version++;\n\n    app.datastore.updateJson(ACCESS_LEVELS_FILE, accessLevels);\n  } finally {\n    await releaseLock(app, lock);\n  }\n};\n","import {\n  filter, values, each, keys,\n} from 'lodash/fp';\nimport { permission } from './permissions';\nimport {\n  getFlattenedHierarchy,\n  isIndex, isRecord,\n} from '../templateApi/hierarchy';\nimport { $ } from '../common';\n\nexport const generateFullPermissions = (app) => {\n  const allNodes = getFlattenedHierarchy(app.hierarchy);\n  const accessLevel = { permissions: [] };\n\n  const recordNodes = $(allNodes, [\n    filter(isRecord),\n  ]);\n\n  for (const n of recordNodes) {\n    permission.createRecord.add(n.nodeKey(), accessLevel);\n    permission.updateRecord.add(n.nodeKey(), accessLevel);\n    permission.deleteRecord.add(n.nodeKey(), accessLevel);\n    permission.readRecord.add(n.nodeKey(), accessLevel);\n  }\n\n  const indexNodes = $(allNodes, [\n    filter(isIndex),\n  ]);\n\n  for (const n of indexNodes) {\n    permission.readIndex.add(n.nodeKey(), accessLevel);\n  }\n\n  for (const a of keys(app.actions)) {\n    permission.executeAction.add(a, accessLevel);\n  }\n\n  $(permission, [\n    values,\n    filter(p => !p.isNode),\n    each(p => p.add(accessLevel)),\n  ]);\n\n  return accessLevel.permissions;\n};\n","import { difference, map, join } from 'lodash/fp';\nimport {\n  getLock, isNolock, releaseLock, $,\n  apiWrapper, events,\n} from '../common';\nimport {\n  USERS_LOCK_FILE, ACCESS_LEVELS_FILE,\n  getUserByName, USERS_LIST_FILE,\n} from './authCommon';\nimport { permission } from './permissions';\nimport { NotFoundError } from '../common/errors';\n\nexport const setUserAccessLevels = app => async (userName, accessLevels) => apiWrapper(\n  app,\n  events.authApi.setUserAccessLevels,\n  permission.setUserAccessLevels.isAuthorized,\n  { userName, accessLevels },\n  _setUserAccessLevels, app, userName, accessLevels,\n);\n\nexport const _setUserAccessLevels = async (app, username, accessLevels) => {\n  const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0);\n\n  const actualAccessLevels = $(\n    await app.datastore.loadJson(ACCESS_LEVELS_FILE),\n    [\n      l => l.levels,\n      map(l => l.name),\n    ],\n  );\n\n  const missing = difference(accessLevels)(actualAccessLevels);\n  if (missing.length > 0) {\n    throw new Error(`Invalid access levels supplied: ${join(', ', missing)}`);\n  }\n\n  if (isNolock(lock)) { throw new Error('Could set user access levels cannot get lock'); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n    const user = getUserByName(users, username);\n    if (!user) { throw new NotFoundError(`Could not find user with ${username}`); }\n\n    user.accessLevels = accessLevels;\n    await app.datastore.updateJson(USERS_LIST_FILE, users);\n  } finally {\n    releaseLock(app, lock);\n  }\n};\n","import {\n  authenticate,\n  authenticateTemporaryAccess,\n} from './authenticate';\nimport { createTemporaryAccess } from './createTemporaryAccess';\nimport { createUser } from './createUser';\nimport { enableUser, disableUser } from './enableUser';\nimport { loadAccessLevels } from './loadAccessLevels';\nimport { getNewAccessLevel } from './getNewAccessLevel';\nimport { getNewUser, getNewUserAuth } from './getNewUser';\nimport { getUsers } from './getUsers';\nimport { isAuthorized } from './isAuthorized';\nimport { saveAccessLevels } from './saveAccessLevels';\nimport {\n  changeMyPassword,\n  scorePassword, setPasswordFromTemporaryCode,\n  isValidPassword,\n} from './setPassword';\nimport { validateUser } from './validateUser';\nimport { validateAccessLevels } from './validateAccessLevels';\nimport { generateFullPermissions } from './generateFullPermissions';\nimport { setUserAccessLevels } from './setUserAccessLevels';\n\nexport const getAuthApi = app => ({\n  authenticate: authenticate(app),\n  authenticateTemporaryAccess: authenticateTemporaryAccess(app),\n  createTemporaryAccess: createTemporaryAccess(app),\n  createUser: createUser(app),\n  loadAccessLevels: loadAccessLevels(app),\n  enableUser: enableUser(app),\n  disableUser: disableUser(app),\n  getNewAccessLevel: getNewAccessLevel(app),\n  getNewUser: getNewUser(app),\n  getNewUserAuth: getNewUserAuth(app),\n  getUsers: getUsers(app),\n  saveAccessLevels: saveAccessLevels(app),\n  isAuthorized: isAuthorized(app),\n  changeMyPassword: changeMyPassword(app),\n  setPasswordFromTemporaryCode: setPasswordFromTemporaryCode(app),\n  scorePassword,\n  isValidPassword: isValidPassword(app),\n  validateUser: validateUser(app),\n  validateAccessLevels: validateAccessLevels(app),\n  generateFullPermissions: () => generateFullPermissions(app),\n  setUserAccessLevels: setUserAccessLevels(app),\n});\n\nexport default getAuthApi;\n","import { permission } from '../authApi/permissions';\nimport { apiWrapperSync } from '../common/apiWrapper';\nimport { events } from '../common/events';\n\nexport const executeAction = app => (actionName, options) => {\n  apiWrapperSync(\n    app,\n    events.actionsApi.execute,\n    permission.executeAction.isAuthorized(actionName),\n    { actionName, options },\n    app.actions[actionName], options,\n  );\n};\n\nexport const _executeAction = (behaviourSources, action, options) => behaviourSources[action.behaviourSource][action.behaviourName](options);\n","import { executeAction } from './execute';\n\nexport const getActionsApi = app => ({\n  execute: executeAction(app),\n});\n\nexport default getActionsApi;\n","import { has } from 'lodash/fp';\n\nconst publish = handlers => async (eventName, context = {}) => {\n  if (!has(eventName)(handlers)) return;\n\n  for (const handler of handlers[eventName]) {\n    await handler(eventName, context);\n  }\n};\n\nconst subscribe = handlers => (eventName, handler) => {\n  if (!has(eventName)(handlers)) {\n    handlers[eventName] = [];\n  }\n  handlers[eventName].push(handler);\n};\n\nexport const createEventAggregator = () => {\n  const handlers = {};\n  const eventAggregator = ({\n    publish: publish(handlers),\n    subscribe: subscribe(handlers),\n  });\n  return eventAggregator;\n};\n\nexport default createEventAggregator;\n","import { retry } from '../common/index';\nimport { NotFoundError } from '../common/errors';\n\nconst createJson = originalCreateFile => async (key, obj, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, key, JSON.stringify(obj));\n\nconst createNewFile = originalCreateFile => async (path, content, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, path, content);\n\nconst loadJson = datastore => async (key, retries = 3, delay = 100) => {\n  try {\n    return await retry(JSON.parse, retries, delay, await datastore.loadFile(key));\n  } catch (err) {\n    const newErr = new NotFoundError(err.message);\n    newErr.stack = err.stack;\n    throw(newErr);\n  }\n}\n\nconst updateJson = datastore => async (key, obj, retries = 3, delay = 100) => {\n  try {\n    return await retry(datastore.updateFile, retries, delay, key, JSON.stringify(obj));\n  } catch (err) {\n    const newErr = new NotFoundError(err.message);\n    newErr.stack = err.stack;\n    throw(newErr);\n  }\n}\n\nexport const setupDatastore = (datastore) => {\n  const originalCreateFile = datastore.createFile;\n  datastore.loadJson = loadJson(datastore);\n  datastore.createJson = createJson(originalCreateFile);\n  datastore.updateJson = updateJson(datastore);\n  datastore.createFile = createNewFile(originalCreateFile);\n  if (datastore.createEmptyDb) { delete datastore.createEmptyDb; }\n  return datastore;\n};\n\nexport { createEventAggregator } from './eventAggregator';\n\nexport default setupDatastore;\n","import { \n  compileExpression as cExp, \n  compileCode as cCode \n} from '@nx-js/compiler-util';\n\nexport const compileCode = code => {\n  let func;  \n    \n  try {\n    func = cCode(code);\n  } catch(e) {\n    e.message = `Error compiling code : ${code} : ${e.message}`;\n    throw e;\n  }\n\n  return func;\n}\n\nexport const compileExpression = code => {\n  let func;  \n      \n  try {\n    func = cExp(code);\n  } catch(e) {\n    e.message = `Error compiling expression : ${code} : ${e.message}`;\n    throw e;\n  }\n  \n  return func;\n}\n","import {\n  isFunction, filter, map,\n  uniqBy, keys, difference,\n  join, reduce, find,\n} from 'lodash/fp';\nimport { compileExpression, compileCode } from '../common/compileCode';\nimport { $ } from '../common';\nimport { _executeAction } from './execute';\nimport { BadRequestError, NotFoundError } from '../common/errors';\n\nexport const initialiseActions = (subscribe, behaviourSources, actions, triggers, apis) => {\n  validateSources(behaviourSources, actions);\n  subscribeTriggers(subscribe, behaviourSources, actions, triggers, apis);\n  return createActionsCollection(behaviourSources, actions);\n};\n\nconst createActionsCollection = (behaviourSources, actions) => $(actions, [\n  reduce((all, a) => {\n    all[a.name] = opts => _executeAction(behaviourSources, a, opts);\n    return all;\n  }, {}),\n]);\n\nconst subscribeTriggers = (subscribe, behaviourSources, actions, triggers, apis) => {\n  const createOptions = (optionsCreator, eventContext) => {\n    if (!optionsCreator) return {};\n    const create = compileCode(optionsCreator);\n    return create({ context: eventContext, apis });\n  };\n\n  const shouldRunTrigger = (trigger, eventContext) => {\n    if (!trigger.condition) return true;\n    const shouldRun = compileExpression(trigger.condition);\n    return shouldRun({ context: eventContext });\n  };\n\n  for (let trig of triggers) {\n    subscribe(trig.eventName, async (ev, ctx) => {\n      if (shouldRunTrigger(trig, ctx)) {\n        await _executeAction(\n          behaviourSources,\n          find(a => a.name === trig.actionName)(actions),\n          createOptions(trig.optionsCreator, ctx),\n        );\n      }\n    });\n  }\n};\n\nconst validateSources = (behaviourSources, actions) => {\n  const declaredSources = $(actions, [\n    uniqBy(a => a.behaviourSource),\n    map(a => a.behaviourSource),\n  ]);\n\n  const suppliedSources = keys(behaviourSources);\n\n  const missingSources = difference(\n    declaredSources, suppliedSources,\n  );\n\n  if (missingSources.length > 0) {\n    throw new BadRequestError(`Declared behaviour sources are not supplied: ${join(', ', missingSources)}`);\n  }\n\n  const missingBehaviours = $(actions, [\n    filter(a => !isFunction(behaviourSources[a.behaviourSource][a.behaviourName])),\n    map(a => `Action: ${a.name} : ${a.behaviourSource}.${a.behaviourName}`),\n  ]);\n\n  if (missingBehaviours.length > 0) {\n    throw new NotFoundError(`Missing behaviours: could not find behaviour functions: ${join(', ', missingBehaviours)}`);\n  }\n};\n","import {\n  map, filter, groupBy, split,\n  some, find,\n} from 'lodash/fp';\nimport {\n  LOCK_FILENAME, TRANSACTIONS_FOLDER, idSep, isUpdate,\n  nodeKeyHashFromBuildFolder, isBuildIndexFolder, getTransactionId,\n  isDelete, isCreate,\n} from './transactionsCommon';\nimport {\n  joinKey, $, none, isSomething,\n} from '../common';\nimport { getLastPartInKey, getNodeFromNodeKeyHash } from '../templateApi/hierarchy';\nimport { _load } from '../recordApi/load';\n\nexport const retrieve = async (app) => {\n  const transactionFiles = await app.datastore.getFolderContents(\n    TRANSACTIONS_FOLDER,\n  );\n\n  let transactions = [];\n\n  if (some(isBuildIndexFolder)(transactionFiles)) {\n    const buildIndexFolder = find(isBuildIndexFolder)(transactionFiles);\n\n    transactions = await retrieveBuildIndexTransactions(\n      app,\n      joinKey(TRANSACTIONS_FOLDER, buildIndexFolder),\n    );\n  }\n\n  if (transactions.length > 0) return transactions;\n\n  return await retrieveStandardTransactions(\n    app, transactionFiles,\n  );\n};\n\nconst retrieveBuildIndexTransactions = async (app, buildIndexFolder) => {\n  const childFolders = await app.datastore.getFolderContents(buildIndexFolder);\n  if (childFolders.length === 0) {\n    // cleanup\n    await app.datastore.deleteFolder(buildIndexFolder);\n    return [];\n  }\n\n  const getTransactionFiles = async (childFolderIndex = 0) => {\n    if (childFolderIndex >= childFolders.length) return [];\n\n    const childFolderKey = joinKey(buildIndexFolder, childFolders[childFolderIndex]);\n    const files = await app.datastore.getFolderContents(\n      childFolderKey,\n    );\n\n    if (files.length === 0) {\n      await app.datastore.deleteFolder(childFolderKey);\n      return await getTransactionFiles(childFolderIndex + 1);\n    }\n\n    return { childFolderKey, files };\n  };\n\n  const transactionFiles = await getTransactionFiles();\n\n  if (transactionFiles.files.length === 0) return [];\n\n  const transactions = $(transactionFiles.files, [\n    map(parseTransactionId),\n  ]);\n\n  for (const t of transactions) {\n    const transactionContent = await app.datastore.loadJson(\n      joinKey(\n        transactionFiles.childFolderKey,\n        t.fullId,\n      ),\n    );\n    t.record = await _load(app, transactionContent.recordKey);\n  }\n\n  transactions.indexNode = $(buildIndexFolder, [\n    getLastPartInKey,\n    nodeKeyHashFromBuildFolder,\n    getNodeFromNodeKeyHash(app.hierarchy),\n  ]);\n\n  transactions.folderKey = transactionFiles.childFolderKey;\n\n  return transactions;\n};\n\nconst retrieveStandardTransactions = async (app, transactionFiles) => {\n  const transactionIds = $(transactionFiles, [\n    filter(f => f !== LOCK_FILENAME\n                    && !isBuildIndexFolder(f)),\n    map(parseTransactionId),\n  ]);\n\n  const transactionIdsByRecord = $(transactionIds, [\n    groupBy('recordId'),\n  ]);\n\n  const dedupedTransactions = [];\n\n  const verify = async (t) => {\n    if (t.verified === true) return t;\n\n    const id = getTransactionId(\n      t.recordId,\n      t.transactionType,\n      t.uniqueId,\n    );\n\n    const transaction = await app.datastore.loadJson(\n      joinKey(TRANSACTIONS_FOLDER, id),\n    );\n\n    if (isDelete(t)) {\n      t.record = transaction.record;\n      t.verified = true;\n      return t;\n    }\n\n    const rec = await _load(\n      app,\n      transaction.recordKey,\n    );\n    if (rec.transactionId === id) {\n      t.record = rec;\n      if (transaction.oldRecord) { t.oldRecord = transaction.oldRecord; }\n      t.verified = true;\n    } else {\n      t.verified = false;\n    }\n\n    return t;\n  };\n\n  const pickOne = async (trans, forType) => {\n    const transForType = filter(forType)(trans);\n    if (transForType.length === 1) {\n      const t = await verify(transForType[0]);\n      return (t.verified === true ? t : null);\n    }\n    for (let t of transForType) {\n      t = await verify(t);\n      if (t.verified === true) { return t; }\n    }\n\n    return null;\n  };\n\n  for (const recordId in transactionIdsByRecord) {\n    const transIdsForRecord = transactionIdsByRecord[recordId];\n    if (transIdsForRecord.length === 1) {\n      const t = await verify(transIdsForRecord[0]);\n      if (t.verified) { dedupedTransactions.push(t); }\n      continue;\n    }\n    if (some(isDelete)(transIdsForRecord)) {\n      const t = await verify(find(isDelete)(transIdsForRecord));\n      if (t.verified) { dedupedTransactions.push(t); }\n      continue;\n    }\n    if (some(isUpdate)(transIdsForRecord)) {\n      const upd = await pickOne(transIdsForRecord, isUpdate);\n      if (isSomething(upd) && upd.verified) { dedupedTransactions.push(upd); }\n      continue;\n    }\n    if (some(isCreate)(transIdsForRecord)) {\n      const cre = await pickOne(transIdsForRecord, isCreate);\n      if (isSomething(cre)) { dedupedTransactions.push(cre); }\n      continue;\n    }\n  }\n\n  const duplicates = $(transactionIds, [\n    filter(t => none(ddt => ddt.uniqueId === t.uniqueId)(dedupedTransactions)),\n  ]);\n\n\n  const deletePromises = map(t => app.datastore.deleteFile(\n    joinKey(\n      TRANSACTIONS_FOLDER,\n      getTransactionId(\n        t.recordId,\n        t.transactionType,\n        t.uniqueId,\n      ),\n    ),\n  ))(duplicates);\n\n  await Promise.all(deletePromises);\n\n  return dedupedTransactions;\n};\n\nconst parseTransactionId = (id) => {\n  const splitId = split(idSep)(id);\n  return ({\n    recordId: splitId[0],\n    transactionType: splitId[1],\n    uniqueId: splitId[2],\n    fullId: id,\n  });\n};\n","import { orderBy } from 'lodash';\nimport {\n  reduce, find, includes, flatten, union,\n  filter, each, map,\n} from 'lodash/fp';\nimport {\n  joinKey, splitKey, isNonEmptyString,\n  isNothing, $, isSomething,\n} from '../common';\nimport {\n  getFlattenedHierarchy, getNode, getRecordNodeId,\n  getExactNodeForKey, recordNodeIdIsAllowed,\n  isRecord, isGlobalIndex,\n} from '../templateApi/hierarchy';\nimport { indexTypes } from '../templateApi/indexes';\nimport { getIndexDir } from \"../indexApi/getIndexDir\";\nimport { getRecordInfo} from \"../recordApi/recordInfo\";\n\nexport const getRelevantAncestorIndexes = (hierarchy, record) => {\n  const key = record.key;\n  const keyParts = splitKey(key);\n  const nodeId = getRecordNodeId(key);\n\n  const flatHierarchy = orderBy(getFlattenedHierarchy(hierarchy),\n    [node => node.pathRegx().length],\n    ['desc']);\n\n  const makeindexNodeAndDir_ForAncestorIndex = (indexNode, parentRecordDir) => makeIndexNodeAndDir(indexNode, joinKey(parentRecordDir, indexNode.name));\n\n  const traverseAncestorIndexesInPath = () => reduce((acc, part) => {\n    const currentIndexKey = joinKey(acc.lastIndexKey, part);\n    acc.lastIndexKey = currentIndexKey;\n    const testPathRegx = p => new RegExp(`${p.pathRegx()}$`).test(currentIndexKey);\n    const nodeMatch = find(testPathRegx)(flatHierarchy);\n\n    if (isNothing(nodeMatch)) { return acc; }\n\n    if (!isRecord(nodeMatch)\n                || nodeMatch.indexes.length === 0) { return acc; }\n\n    const indexes = $(nodeMatch.indexes, [\n      filter(i => i.indexType === indexTypes.ancestor\n                        && (i.allowedRecordNodeIds.length === 0\n                         || includes(nodeId)(i.allowedRecordNodeIds))),\n    ]);\n\n    const currentRecordDir = getRecordInfo(hierarchy, currentIndexKey).dir;\n\n    each(v => acc.nodesAndKeys.push(\n      makeindexNodeAndDir_ForAncestorIndex(v, currentRecordDir),\n    ))(indexes);\n\n    return acc;\n  }, { lastIndexKey: '', nodesAndKeys: [] })(keyParts).nodesAndKeys;\n\n  const rootIndexes = $(flatHierarchy, [\n    filter(n => isGlobalIndex(n) && recordNodeIdIsAllowed(n)(nodeId)),\n    map(i => makeIndexNodeAndDir(\n              i, \n              getIndexDir(hierarchy, i.nodeKey()))),\n  ]);\n\n  return union(traverseAncestorIndexesInPath())(rootIndexes);\n};\n\nexport const getRelevantReverseReferenceIndexes = (hierarchy, record) => $(record.key, [\n  getExactNodeForKey(hierarchy),\n  n => n.fields,\n  filter(f => f.type === 'reference'\n                    && isSomething(record[f.name])\n                    && isNonEmptyString(record[f.name].key)),\n  map(f => $(f.typeOptions.reverseIndexNodeKeys, [\n    map(n => ({\n      recordNode: getNode(hierarchy, n),\n      field: f,\n    })),\n  ])),\n  flatten,\n  map(n => makeIndexNodeAndDir(\n    n.recordNode,\n    joinKey(\n      getRecordInfo(hierarchy, record[n.field.name].key).dir, \n      n.recordNode.name),\n  )),\n]);\n\nconst makeIndexNodeAndDir = (indexNode, indexDir) => ({ indexNode, indexDir });\n\nexport default getRelevantAncestorIndexes;\n","  // adapted from https://github.com/dex4er/js-promise-writable\n  // Thank you :) \n  export const promiseWriteableStream = stream => {\n  \n    let _errored;\n  \n    const _errorHandler = err => {\n        _errored = err;\n    };\n\n    stream.on(\"error\", _errorHandler);    \n  \n    const write = chunk => {  \n      let rejected = false;\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err);\n        }\n  \n        if (!stream.writable || stream.closed || stream.destroyed) {\n          return reject(new Error(\"write after end\"));\n        }\n  \n        const writeErrorHandler = err => {\n          _errored = undefined;\n          rejected = true;\n          reject(err);\n        }\n  \n        stream.once(\"error\", writeErrorHandler);\n  \n        const canWrite = stream.write(chunk);\n  \n        stream.removeListener(\"error\", writeErrorHandler);\n  \n        if (canWrite) {\n          if (!rejected) {\n            resolve(chunk.length);\n          }\n        } else {\n          const errorHandler = err => {\n            _errored = undefined;\n            removeListeners();\n            reject(err);\n          }\n  \n          const drainHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const closeHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const finishHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const removeListeners = () => {\n            stream.removeListener(\"close\", closeHandler);\n            stream.removeListener(\"drain\", drainHandler);\n            stream.removeListener(\"error\", errorHandler);\n            stream.removeListener(\"finish\", finishHandler);\n          }\n  \n          stream.on(\"close\", closeHandler);\n          stream.on(\"drain\", drainHandler);\n          stream.on(\"error\", errorHandler);\n          stream.on(\"finish\", finishHandler);\n        }\n      })\n    }\n  \n    const end = () => {\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err);\n        }\n  \n        if (!stream.writable || stream.closed || stream.destroyed) {\n          return resolve();\n        }\n  \n        const finishHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const errorHandler = (err) => {\n          _errored = undefined;\n          removeListeners();\n          reject(err);\n        }\n  \n        const removeListeners = () => {\n          stream.removeListener(\"error\", errorHandler);\n          stream.removeListener(\"finish\", finishHandler);\n        }\n  \n        stream.on(\"finish\", finishHandler);\n        stream.on(\"error\", errorHandler);\n  \n        stream.end();\n      })\n    }\n\n    return {write, end};\n  }\n  \n  export default promiseWriteableStream\n  ","import { ensureShardNameIsInShardMap } from './sharding';\nimport { getIndexWriter } from './serializer';\nimport { isShardedIndex, getParentKey } from '../templateApi/hierarchy';\nimport {promiseWriteableStream} from \"./promiseWritableStream\";\nimport {promiseReadableStream} from \"./promiseReadableStream\";\n\nexport const applyToShard = async (hierarchy, store, indexDir,\n  indexNode, indexShardKey, recordsToWrite, keysToRemove) => {\n  const createIfNotExists = recordsToWrite.length > 0;\n  const writer = await getWriter(hierarchy, store, indexDir, indexShardKey, indexNode, createIfNotExists);\n  if (writer === SHARD_DELETED) return;\n\n  await writer.updateIndex(recordsToWrite, keysToRemove);\n  await swapTempFileIn(store, indexShardKey);\n};\n\nconst SHARD_DELETED = 'SHARD_DELETED';\nconst getWriter = async (hierarchy, store, indexDir, indexedDataKey, indexNode, createIfNotExists) => {\n  let readableStream = null;\n\n  if (isShardedIndex(indexNode)) {\n    await ensureShardNameIsInShardMap(store, indexDir, indexedDataKey);\n    if(!await store.exists(indexedDataKey)) {\n      if (await store.exists(getParentKey(indexedDataKey))) {\n        await store.createFile(indexedDataKey, \"\");\n      } else {\n        return SHARD_DELETED;\n      }\n    }\n  }\n\n  try {\n\n    readableStream = promiseReadableStream(\n        await store.readableFileStream(indexedDataKey)\n    );\n\n  } catch (e) {\n\n    if (await store.exists(indexedDataKey)) {\n      throw e;\n    } else {\n      if (createIfNotExists) { \n        if(await store.exists(getParentKey(indexedDataKey))) {\n          await store.createFile(indexedDataKey, '');     \n        } else {\n          return SHARD_DELETED; \n        }\n      } else { \n        return SHARD_DELETED; \n      }\n\n      readableStream = promiseReadableStream(\n          await store.readableFileStream(indexedDataKey)\n      );\n\n    }\n  }\n\n  const writableStream = promiseWriteableStream(\n      await store.writableFileStream(indexedDataKey + \".temp\")\n  );\n\n  return getIndexWriter(\n    hierarchy, indexNode,\n        readableStream, writableStream\n  );\n};\n\nconst swapTempFileIn = async (store, indexedDataKey, isRetry = false) => {\n  const tempFile = `${indexedDataKey}.temp`;\n  try {\n    await store.deleteFile(indexedDataKey);\n  } catch (e) {\n    // ignore failure, incase it has not been created yet\n\n    // if parent folder does not exist, assume that this index\n    // should not be there\n    if(!await store.exists(getParentKey(indexedDataKey))) {\n      return;\n    }\n  }\n  try {\n    await store.renameFile(tempFile, indexedDataKey);\n  } catch (e) {\n    // retrying in case delete failure was for some other reason\n    if (!isRetry) {\n      await swapTempFileIn(store, indexedDataKey, true);\n    } else {\n      throw new Error(\"Failed to swap in index filed: \" + e.message);\n    }\n  }\n};\n","import {\n  filter, map, isUndefined, includes,\n  flatten, intersectionBy,\n  isEqual, pull, keys,\n  differenceBy, difference,\n} from 'lodash/fp';\nimport { union } from 'lodash';\nimport {\n  getRelevantAncestorIndexes,\n  getRelevantReverseReferenceIndexes,\n} from '../indexing/relevant';\nimport { evaluate } from '../indexing/evaluate';\nimport {\n  $, isSomething,\n  isNonEmptyArray, joinKey,\n  isNonEmptyString,\n} from '../common';\nimport { getIndexedDataKey } from '../indexing/sharding';\nimport {\n  isUpdate, isCreate,\n  isDelete, isBuildIndex,\n} from './transactionsCommon';\nimport { applyToShard } from '../indexing/apply';\nimport {\n  getActualKeyOfParent,\n  isGlobalIndex, fieldReversesReferenceToIndex, isReferenceIndex,\n  getExactNodeForKey,\n} from '../templateApi/hierarchy';\nimport { getRecordInfo } from \"../recordApi/recordInfo\";\nimport { getIndexDir } from '../indexApi/getIndexDir';\n\nexport const executeTransactions = app => async (transactions) => {\n  const recordsByShard = mappedRecordsByIndexShard(app.hierarchy, transactions);\n\n  for (const shard of keys(recordsByShard)) {\n    await applyToShard(\n      app.hierarchy, app.datastore,\n      recordsByShard[shard].indexDir,\n      recordsByShard[shard].indexNode,\n      shard,\n      recordsByShard[shard].writes,\n      recordsByShard[shard].removes,\n    );\n  }\n};\n\nconst mappedRecordsByIndexShard = (hierarchy, transactions) => {\n  const updates = getUpdateTransactionsByShard(\n    hierarchy, transactions,\n  );\n\n  const created = getCreateTransactionsByShard(\n    hierarchy, transactions,\n  );\n  const deletes = getDeleteTransactionsByShard(\n    hierarchy, transactions,\n  );\n\n  const indexBuild = getBuildIndexTransactionsByShard(\n    hierarchy,\n    transactions,\n  );\n\n  const toRemove = [\n    ...deletes,\n    ...updates.toRemove,\n  ];\n\n  const toWrite = [\n    ...created,\n    ...updates.toWrite,\n    ...indexBuild,\n  ];\n\n  const transByShard = {};\n\n  const initialiseShard = (t) => {\n    if (isUndefined(transByShard[t.indexShardKey])) {\n      transByShard[t.indexShardKey] = {\n        writes: [],\n        removes: [],\n        indexDir: t.indexDir,\n        indexNodeKey: t.indexNode.nodeKey(),\n        indexNode: t.indexNode,\n      };\n    }\n  };\n\n  for (const trans of toWrite) {\n    initialiseShard(trans);\n    transByShard[trans.indexShardKey].writes.push(\n      trans.mappedRecord.result,\n    );\n  }\n\n  for (const trans of toRemove) {\n    initialiseShard(trans);\n    transByShard[trans.indexShardKey].removes.push(\n      trans.mappedRecord.result.key,\n    );\n  }\n\n  return transByShard;\n};\n\nconst getUpdateTransactionsByShard = (hierarchy, transactions) => {\n  const updateTransactions = $(transactions, [filter(isUpdate)]);\n\n  const evaluateIndex = (record, indexNodeAndPath) => {\n    const mappedRecord = evaluate(record)(indexNodeAndPath.indexNode);\n    return ({\n      mappedRecord,\n      indexNode: indexNodeAndPath.indexNode,\n      indexDir: indexNodeAndPath.indexDir,\n      indexShardKey: getIndexedDataKey(\n        indexNodeAndPath.indexNode,\n        indexNodeAndPath.indexDir,\n        mappedRecord.result,\n      ),\n    });\n  };\n\n  const getIndexNodesToApply = indexFilter => (t, indexes) => $(indexes, [\n    map(n => ({\n      old: evaluateIndex(t.oldRecord, n),\n      new: evaluateIndex(t.record, n),\n    })),\n    filter(indexFilter),\n  ]);\n\n  const toRemoveFilter = (n, isUnreferenced) => n.old.mappedRecord.passedFilter === true\n        && (n.new.mappedRecord.passedFilter === false\n            || isUnreferenced);\n\n  const toAddFilter = (n, isNewlyReferenced) => (n.old.mappedRecord.passedFilter === false\n        || isNewlyReferenced)\n        && n.new.mappedRecord.passedFilter === true;\n\n  const toUpdateFilter = n => n.new.mappedRecord.passedFilter === true\n        && n.old.mappedRecord.passedFilter === true\n        && !isEqual(n.old.mappedRecord.result,\n          n.new.mappedRecord.result);\n\n  const toRemove = [];\n  const toWrite = [];\n\n  for (const t of updateTransactions) {\n    const ancestorIdxs = getRelevantAncestorIndexes(\n      hierarchy, t.record,\n    );\n\n    const referenceChanges = diffReverseRefForUpdate(\n      hierarchy, t.oldRecord, t.record,\n    );\n\n    // old records to remove (filtered out)\n    const filteredOut_toRemove = union(\n      getIndexNodesToApply(toRemoveFilter)(t, ancestorIdxs),\n      // still referenced - check filter\n      getIndexNodesToApply(toRemoveFilter)(t, referenceChanges.notChanged),\n      // un referenced - remove if in there already\n      getIndexNodesToApply(n => toRemoveFilter(n, true))(t, referenceChanges.unReferenced),\n    );\n\n    // new records to add (filtered in)\n    const filteredIn_toAdd = union(\n      getIndexNodesToApply(toAddFilter)(t, ancestorIdxs),\n      // newly referenced - check filter\n      getIndexNodesToApply(n => toAddFilter(n, true))(t, referenceChanges.newlyReferenced),\n      // reference unchanged - rerun filter in case something else changed\n      getIndexNodesToApply(toAddFilter)(t, referenceChanges.notChanged),\n    );\n\n    const changed = union(\n      getIndexNodesToApply(toUpdateFilter)(t, ancestorIdxs),\n      // still referenced - recheck filter\n      getIndexNodesToApply(toUpdateFilter)(t, referenceChanges.notChanged),\n    );\n\n    const shardKeyChanged = $(changed, [\n      filter(c => c.old.indexShardKey !== c.new.indexShardKey),\n    ]);\n\n    const changedInSameShard = $(shardKeyChanged, [\n      difference(changed),\n    ]);\n\n    for (const res of shardKeyChanged) {\n      pull(res)(changed);\n      filteredOut_toRemove.push(res);\n      filteredIn_toAdd.push(res);\n    }\n\n    toRemove.push(\n      $(filteredOut_toRemove, [\n        map(i => i.old),\n      ]),\n    );\n\n    toWrite.push(\n      $(filteredIn_toAdd, [\n        map(i => i.new),\n      ]),\n    );\n\n    toWrite.push(\n      $(changedInSameShard, [\n        map(i => i.new),\n      ]),\n    );\n  }\n\n  return ({\n    toRemove: flatten(toRemove),\n    toWrite: flatten(toWrite),\n  });\n};\n\nconst getBuildIndexTransactionsByShard = (hierarchy, transactions) => {\n  const buildTransactions = $(transactions, [filter(isBuildIndex)]);\n  if (!isNonEmptyArray(buildTransactions)) return [];\n  const indexNode = transactions.indexNode;\n\n  const getIndexDirs = (t) => {\n    if (isGlobalIndex(indexNode)) {\n      return [indexNode.nodeKey()];\n    }\n\n    if (isReferenceIndex(indexNode)) {\n      const recordNode = getExactNodeForKey(hierarchy)(t.record.key);\n      const refFields = $(recordNode.fields, [\n        filter(fieldReversesReferenceToIndex(indexNode)),\n      ]);\n      const indexDirs = [];\n      for (const refField of refFields) {\n        const refValue = t.record[refField.name];\n        if (isSomething(refValue)\n                   && isNonEmptyString(refValue.key)) {\n          const indexDir = joinKey(\n            getRecordInfo(hierarchy, refValue.key).dir,\n            indexNode.name,\n          );\n\n          if (!includes(indexDir)(indexDirs)) { indexDirs.push(indexDir); }\n        }\n      }\n      return indexDirs;\n    }\n\n    const indexKey = joinKey(\n      getActualKeyOfParent(\n        indexNode.parent().nodeKey(),\n        t.record.key,\n      ),\n      indexNode.name,\n    );\n\n    return [getIndexDir(hierarchy, indexKey)];\n  };\n\n  return $(buildTransactions, [\n    map((t) => {\n      const mappedRecord = evaluate(t.record)(indexNode);\n      if (!mappedRecord.passedFilter) return null;\n      const indexDirs = getIndexDirs(t);\n      return $(indexDirs, [\n        map(indexDir => ({\n          mappedRecord,\n          indexNode,\n          indexDir,\n          indexShardKey: getIndexedDataKey(\n            indexNode,\n            indexDir,\n            mappedRecord.result,\n          ),\n        })),\n      ]);\n    }),\n    flatten,\n    filter(isSomething),\n  ]);\n};\n\nconst get_Create_Delete_TransactionsByShard = pred => (hierarchy, transactions) => {\n  const createTransactions = $(transactions, [filter(pred)]);\n\n  const getIndexNodesToApply = (t, indexes) => $(indexes, [\n    map((n) => {\n      const mappedRecord = evaluate(t.record)(n.indexNode);\n      return ({\n        mappedRecord,\n        indexNode: n.indexNode,\n        indexDir: n.indexDir,\n        indexShardKey: getIndexedDataKey(\n          n.indexNode,\n          n.indexDir,\n          mappedRecord.result,\n        ),\n      });\n    }),\n    filter(n => n.mappedRecord.passedFilter),\n  ]);\n\n  const allToApply = [];\n\n  for (const t of createTransactions) {\n    const ancestorIdxs = getRelevantAncestorIndexes(hierarchy, t.record);\n    const reverseRef = getRelevantReverseReferenceIndexes(hierarchy, t.record);\n\n    allToApply.push(\n      getIndexNodesToApply(t, ancestorIdxs),\n    );\n    allToApply.push(\n      getIndexNodesToApply(t, reverseRef),\n    );\n  }\n\n  return flatten(allToApply);\n};\n\nconst getDeleteTransactionsByShard = get_Create_Delete_TransactionsByShard(isDelete);\n\nconst getCreateTransactionsByShard = get_Create_Delete_TransactionsByShard(isCreate);\n\nconst diffReverseRefForUpdate = (appHierarchy, oldRecord, newRecord) => {\n  const oldIndexes = getRelevantReverseReferenceIndexes(\n    appHierarchy, oldRecord,\n  );\n  const newIndexes = getRelevantReverseReferenceIndexes(\n    appHierarchy, newRecord,\n  );\n\n  const unReferenced = differenceBy(\n    i => i.indexDir,\n    oldIndexes, newIndexes,\n  );\n\n  const newlyReferenced = differenceBy(\n    i => i.indexDir,\n    newIndexes, oldIndexes,\n  );\n\n  const notChanged = intersectionBy(\n    i => i.indexDir,\n    newIndexes, oldIndexes,\n  );\n\n  return {\n    unReferenced,\n    newlyReferenced,\n    notChanged,\n  };\n};\n","import { map } from 'lodash/fp';\nimport { retrieve } from './retrieve';\nimport { executeTransactions } from './execute';\nimport {\n  $, joinKey, getLock, isNolock, releaseLock,\n} from '../common';\nimport {\n  LOCK_FILE_KEY, TRANSACTIONS_FOLDER,\n  timeoutMilliseconds, getTransactionId,\n  maxLockRetries,\n} from './transactionsCommon';\n\nexport const cleanup = async (app) => {\n  const lock = await getTransactionLock(app);\n  if (isNolock(lock)) return;\n\n  try {\n    const transactions = await retrieve(app);\n    if (transactions.length > 0) {\n      await executeTransactions(app)(transactions);\n\n      const folder = transactions.folderKey\n        ? transactions.folderKey\n        : TRANSACTIONS_FOLDER;\n\n      const deleteFiles = $(transactions, [\n        map(t => joinKey(\n          folder,\n          getTransactionId(\n            t.recordId, t.transactionType,\n            t.uniqueId,\n          ),\n        )),\n        map(app.datastore.deleteFile),\n      ]);\n\n      await Promise.all(deleteFiles);\n    }\n  } finally {\n    await releaseLock(app, lock);\n  }\n};\n\nconst getTransactionLock = async app => await getLock(\n  app, LOCK_FILE_KEY,\n  timeoutMilliseconds, maxLockRetries,\n);\n","import { filter } from 'lodash/fp';\nimport { configFolder, appDefinitionFile, $ } from '../common';\nimport { TRANSACTIONS_FOLDER } from '../transactions/transactionsCommon';\nimport { AUTH_FOLDER, USERS_LIST_FILE, ACCESS_LEVELS_FILE } from '../authApi/authCommon';\nimport { initialiseRootCollections } from '../collectionApi/initialise';\nimport { initialiseIndex } from '../indexing/initialiseIndex';\nimport { getFlattenedHierarchy, isGlobalIndex, isSingleRecord } from '../templateApi/hierarchy';\nimport { _getNew } from \"../recordApi/getNew\";\nimport { _save } from \"../recordApi/save\";\n\nexport const initialiseData = async (datastore, applicationDefinition, accessLevels) => {\n  await datastore.createFolder(configFolder);\n  await datastore.createJson(appDefinitionFile, applicationDefinition);\n\n  await initialiseRootCollections(datastore, applicationDefinition.hierarchy);\n  await initialiseRootIndexes(datastore, applicationDefinition.hierarchy);\n\n  await datastore.createFolder(TRANSACTIONS_FOLDER);\n\n  await datastore.createFolder(AUTH_FOLDER);\n\n  await datastore.createJson(USERS_LIST_FILE, []);\n\n  await datastore.createJson(\n    ACCESS_LEVELS_FILE, \n    accessLevels ? accessLevels : { version: 0, levels: [] });\n\n  await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy);\n};\n\nconst initialiseRootIndexes = async (datastore, hierarchy) => {\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n  const globalIndexes = $(flathierarchy, [\n    filter(isGlobalIndex),\n  ]);\n\n  for (const index of globalIndexes) {\n    if (!await datastore.exists(index.nodeKey())) { \n      await initialiseIndex(datastore, '', index); \n    }\n  }\n};\n\nconst initialiseRootSingleRecords = async (datastore, hierarchy) => {\n  const app = { \n    publish:()=>{},\n    cleanupTransactions: () => {},\n    datastore, hierarchy \n  };\n\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n  const singleRecords = $(flathierarchy, [\n    filter(isSingleRecord),\n  ]);\n\n  for (let record of singleRecords) {\n    await datastore.createFolder(record.nodeKey());\n    const result = _getNew(record, \"\");\n    await _save(app,result);\n  }\n};\n","import { isNothing } from '../common';\n\nexport const getDatabaseManager = databaseManager => ({\n  createEmptyMasterDb: createEmptyMasterDb(databaseManager),\n  createEmptyInstanceDb: createEmptyInstanceDb(databaseManager),\n  getInstanceDbRootConfig: databaseManager.getInstanceDbRootConfig,\n  masterDatastoreConfig: getMasterDatastoreConfig(databaseManager),\n  getInstanceDatastoreConfig: getInstanceDatastoreConfig(databaseManager),\n});\n\nconst getMasterDatastoreConfig = databaseManager => databaseManager.getDatastoreConfig('master');\n\nconst getInstanceDatastoreConfig = databaseManager => (applicationId, instanceId) => databaseManager.getDatastoreConfig(\n  applicationId, instanceId,\n);\n\nconst createEmptyMasterDb = databaseManager => async () => await databaseManager.createEmptyDb('master');\n\nconst createEmptyInstanceDb = databaseManager => async (applicationId, instanceId) => {\n  if (isNothing(applicationId)) { throw new Error('CreateDb: application id not supplied'); }\n  if (isNothing(instanceId)) { throw new Error('CreateDb: instance id not supplied'); }\n\n  return await databaseManager.createEmptyDb(\n    applicationId,\n    instanceId,\n  );\n};\n","import getRecordApi from \"./recordApi\";\nimport getCollectionApi from \"./collectionApi\";\nimport getIndexApi from \"./indexApi\";\nimport getTemplateApi from \"./templateApi\";\nimport getAuthApi from \"./authApi\";\nimport getActionsApi from \"./actionsApi\";\nimport {setupDatastore, createEventAggregator} from \"./appInitialise\";\nimport {initialiseActions} from \"./actionsApi/initialise\"\nimport {isSomething} from \"./common\";\nimport {cleanup} from \"./transactions/cleanup\";\nimport {generateFullPermissions} from \"./authApi/generateFullPermissions\";\nimport {getApplicationDefinition} from \"./templateApi/getApplicationDefinition\";\nimport common from \"./common\";\nimport {getBehaviourSources} from \"./templateApi/getBehaviourSources\";\nimport hierarchy from \"./templateApi/hierarchy\";\n\nexport const getAppApis = async (store, behaviourSources = null, \n                                cleanupTransactions = null, \n                                getEpochTime = null,\n                                crypto = null,\n                                appDefinition = null) => {\n\n    store = setupDatastore(store);\n\n    if(!appDefinition)\n        appDefinition = await getApplicationDefinition(store)();\n\n    if(!behaviourSources)\n        behaviourSources = await getBehaviourSources(store);\n\n    const eventAggregator = createEventAggregator();\n\n    const app = {\n        datastore:store,\n        crypto,\n        publish:eventAggregator.publish,\n        hierarchy:appDefinition.hierarchy,\n        actions:appDefinition.actions\n    };\n\n    const templateApi = getTemplateApi(app);    \n\n    app.cleanupTransactions = isSomething(cleanupTransactions) \n                              ? cleanupTransactions\n                              : async () => await cleanup(app);\n\n    app.getEpochTime = isSomething(getEpochTime)\n                       ? getEpochTime\n                       : async () => (new Date()).getTime();\n\n    const recordApi = getRecordApi(app);\n    const collectionApi = getCollectionApi(app);\n    const indexApi = getIndexApi(app);\n    const authApi = getAuthApi(app);\n    const actionsApi = getActionsApi(app);\n\n    const authenticateAs = async (username, password) => {\n        app.user = await authApi.authenticate(username, password);\n    };\n\n    const withFullAccess = () => \n        userWithFullAccess(app);    \n\n    const asUser = (user) => {\n        app.user = user\n    };    \n\n    let apis = {\n        recordApi, \n        templateApi,\n        collectionApi,\n        indexApi,\n        authApi,\n        actionsApi,\n        subscribe: eventAggregator.subscribe,\n        authenticateAs,\n        withFullAccess,\n        asUser\n    };\n\n    apis.actions = initialiseActions(\n        eventAggregator.subscribe,\n        behaviourSources,\n        appDefinition.actions,\n        appDefinition.triggers,\n        apis);\n\n\n    return apis;\n};\n\nexport const userWithFullAccess = (app) => {\n    app.user = {\n        name: \"app\",\n        permissions : generateFullPermissions(app),\n        isUser:false,\n        temp:false\n    }\n    return app.user;\n};\n\nexport {events, eventsList} from \"./common/events\";\nexport {getTemplateApi} from \"./templateApi\";\nexport {getRecordApi} from \"./recordApi\";\nexport {getCollectionApi} from \"./collectionApi\";\nexport {getAuthApi} from \"./authApi\";\nexport {getIndexApi} from \"./indexApi\";\nexport {setupDatastore} from \"./appInitialise\";\nexport {getActionsApi} from \"./actionsApi\";\nexport {initialiseData} from \"./appInitialise/initialiseData\";\nexport {getDatabaseManager} from \"./appInitialise/databaseManager\";\nexport {hierarchy};\nexport {common};\n\nexport default getAppApis;"],"names":["isArray","join","isNaN","compileExpression","compileCode","makerule","options","typeConstraints","all","getDefaultOptions","validateTypeConstraints","global","base64.fromByteArray","ieee754.read","ieee754.write","base64.toByteArray","read","Buffer","readIndex","merge","takeRight","deleteRecord","validate","find","each","defaultCase","api","createTemporaryAccess","createUser","setUserAccessLevels","executeAction","cCode","cExp","orderBy","union"],"mappings":"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"} diff --git a/packages/core/dist/budibase-core.umd.js b/packages/core/dist/budibase-core.umd.js deleted file mode 100644 index 1af3ff91ec..0000000000 --- a/packages/core/dist/budibase-core.umd.js +++ /dev/null @@ -1,8296 +0,0 @@ -(function (global, factory) { - typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('lodash/fp'), require('shortid'), require('lodash'), require('@nx-js/compiler-util'), require('lunr'), require('safe-buffer')) : - typeof define === 'function' && define.amd ? define(['exports', 'lodash/fp', 'shortid', 'lodash', '@nx-js/compiler-util', 'lunr', 'safe-buffer'], factory) : - (global = global || self, factory(global['@budibase/core'] = {}, global.fp, global.shortid, global._, global.compiler_util, global.lunr, global.safe_buffer)); -}(this, function (exports, fp, shortid, _, compilerUtil, lunr, safeBuffer) { 'use strict'; - - var ___default = 'default' in _ ? _['default'] : _; - lunr = lunr && lunr.hasOwnProperty('default') ? lunr['default'] : lunr; - - const commonPlus = extra => fp.union(['onBegin', 'onComplete', 'onError'])(extra); - - const common = () => commonPlus([]); - - const _events = { - recordApi: { - save: commonPlus([ - 'onInvalid', - 'onRecordUpdated', - 'onRecordCreated']), - delete: common(), - getContext: common(), - getNew: common(), - load: common(), - validate: common(), - uploadFile: common(), - downloadFile: common(), - }, - indexApi: { - buildIndex: common(), - listItems: common(), - delete: common(), - aggregates: common(), - }, - collectionApi: { - getAllowedRecordTypes: common(), - initialise: common(), - delete: common(), - }, - authApi: { - authenticate: common(), - authenticateTemporaryAccess: common(), - createTemporaryAccess: common(), - createUser: common(), - enableUser: common(), - disableUser: common(), - loadAccessLevels: common(), - getNewAccessLevel: common(), - getNewUser: common(), - getNewUserAuth: common(), - getUsers: common(), - saveAccessLevels: common(), - isAuthorized: common(), - changeMyPassword: common(), - setPasswordFromTemporaryCode: common(), - scorePassword: common(), - isValidPassword: common(), - validateUser: common(), - validateAccessLevels: common(), - setUserAccessLevels: common(), - }, - templateApi: { - saveApplicationHierarchy: common(), - saveActionsAndTriggers: common(), - }, - actionsApi: { - execute: common(), - }, - }; - - const _eventsList = []; - - const makeEvent = (area, method, name) => `${area}:${method}:${name}`; - - for (const areaKey in _events) { - for (const methodKey in _events[areaKey]) { - _events[areaKey][methodKey] = fp.reduce((obj, s) => { - obj[s] = makeEvent(areaKey, methodKey, s); - return obj; - }, - {})(_events[areaKey][methodKey]); - } - } - - - for (const areaKey in _events) { - for (const methodKey in _events[areaKey]) { - for (const name in _events[areaKey][methodKey]) { - _eventsList.push( - _events[areaKey][methodKey][name], - ); - } - } - } - - - const events = _events; - - const eventsList = _eventsList; - - class BadRequestError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 400; - } - } - - class UnauthorisedError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 401; - } - } - - class ForbiddenError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 403; - } - } - - class NotFoundError extends Error { - constructor(message) { - super(message); - this.httpStatusCode = 404; - } - } - - const apiWrapper = async (app, eventNamespace, isAuthorized, eventContext, func, ...params) => { - pushCallStack(app, eventNamespace); - - if (!isAuthorized(app)) { - handleNotAuthorized(app, eventContext, eventNamespace); - return; - } - - const startDate = Date.now(); - const elapsed = () => (Date.now() - startDate); - - try { - await app.publish( - eventNamespace.onBegin, - eventContext, - ); - - const result = await func(...params); - - await publishComplete(app, eventContext, eventNamespace, elapsed, result); - return result; - } catch (error) { - await publishError(app, eventContext, eventNamespace, elapsed, error); - throw error; - } - }; - - const apiWrapperSync = (app, eventNamespace, isAuthorized, eventContext, func, ...params) => { - pushCallStack(app, eventNamespace); - - if (!isAuthorized(app)) { - handleNotAuthorized(app, eventContext, eventNamespace); - return; - } - - const startDate = Date.now(); - const elapsed = () => (Date.now() - startDate); - - try { - app.publish( - eventNamespace.onBegin, - eventContext, - ); - - const result = func(...params); - - publishComplete(app, eventContext, eventNamespace, elapsed, result); - return result; - } catch (error) { - publishError(app, eventContext, eventNamespace, elapsed, error); - throw error; - } - }; - - const handleNotAuthorized = (app, eventContext, eventNamespace) => { - const err = new UnauthorisedError(`Unauthorized: ${eventNamespace}`); - publishError(app, eventContext, eventNamespace, () => 0, err); - throw err; - }; - - const pushCallStack = (app, eventNamespace, seedCallId) => { - const callId = shortid.generate(); - - const createCallStack = () => ({ - seedCallId: !fp.isUndefined(seedCallId) - ? seedCallId - : callId, - threadCallId: callId, - stack: [], - }); - - if (fp.isUndefined(app.calls)) { - app.calls = createCallStack(); - } - - app.calls.stack.push({ - namespace: eventNamespace, - callId, - }); - }; - - const popCallStack = (app) => { - app.calls.stack.pop(); - if (app.calls.stack.length === 0) { - delete app.calls; - } - }; - - const publishError = async (app, eventContext, eventNamespace, elapsed, err) => { - const ctx = fp.cloneDeep(eventContext); - ctx.error = err; - ctx.elapsed = elapsed(); - await app.publish( - eventNamespace.onError, - ctx, - ); - popCallStack(app); - }; - - const publishComplete = async (app, eventContext, eventNamespace, elapsed, result) => { - const endcontext = fp.cloneDeep(eventContext); - endcontext.result = result; - endcontext.elapsed = elapsed(); - await app.publish( - eventNamespace.onComplete, - endcontext, - ); - popCallStack(app); - return result; - }; - - const lockOverlapMilliseconds = 10; - - const getLock = async (app, lockFile, timeoutMilliseconds, maxLockRetries, retryCount = 0) => { - try { - const timeout = (await app.getEpochTime()) - + timeoutMilliseconds; - - const lock = { - timeout, - key: lockFile, - totalTimeout: timeoutMilliseconds, - }; - - await app.datastore.createFile( - lockFile, - getLockFileContent( - lock.totalTimeout, - lock.timeout, - ), - ); - - return lock; - } catch (e) { - if (retryCount == maxLockRetries) { return NO_LOCK; } - - const lock = parseLockFileContent( - lockFile, - await app.datastore.loadFile(lockFile), - ); - - const currentEpochTime = await app.getEpochTime(); - - if (currentEpochTime < lock.timeout) { - return NO_LOCK; - } - - try { - await app.datastore.deleteFile(lockFile); - } catch (_) { - //empty - } - - await sleepForRetry(); - - return await getLock( - app, lockFile, timeoutMilliseconds, - maxLockRetries, retryCount + 1, - ); - } - }; - - const getLockFileContent = (totalTimeout, epochTime) => `${totalTimeout}:${epochTime.toString()}`; - - const parseLockFileContent = (key, content) => $(content, [ - fp.split(':'), - parts => ({ - totalTimeout: new Number(parts[0]), - timeout: new Number(parts[1]), - key, - }), - ]); - - const releaseLock = async (app, lock) => { - const currentEpochTime = await app.getEpochTime(); - // only release if not timedout - if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) { - try { - await app.datastore.deleteFile(lock.key); - } catch (_) { - //empty - } - } - }; - - const NO_LOCK = 'no lock'; - const isNolock = id => id === NO_LOCK; - - const sleepForRetry = () => new Promise(resolve => setTimeout(resolve, lockOverlapMilliseconds)); - - // this is the combinator function - const $$ = (...funcs) => arg => _.flow(funcs)(arg); - - // this is the pipe function - const $ = (arg, funcs) => $$(...funcs)(arg); - - const keySep = '/'; - const trimKeySep = str => _.trim(str, keySep); - const splitByKeySep = str => fp.split(keySep)(str); - const safeKey = key => _.replace(`${keySep}${trimKeySep(key)}`, `${keySep}${keySep}`, keySep); - const joinKey = (...strs) => { - const paramsOrArray = strs.length === 1 & fp.isArray(strs[0]) - ? strs[0] : strs; - return $(paramsOrArray, [ - fp.filter(s => !fp.isUndefined(s) - && !fp.isNull(s) - && s.toString().length > 0), - fp.join(keySep), - safeKey - ]); - }; - const splitKey = $$(trimKeySep, splitByKeySep); - const getDirFomKey = $$(splitKey, _.dropRight, p => joinKey(...p)); - const getFileFromKey = $$(splitKey, _.takeRight, _.head); - - const configFolder = `${keySep}.config`; - const fieldDefinitions = joinKey(configFolder, 'fields.json'); - const templateDefinitions = joinKey(configFolder, 'templates.json'); - const appDefinitionFile = joinKey(configFolder, 'appDefinition.json'); - const dirIndex = folderPath => joinKey(configFolder, 'dir', ...splitKey(folderPath), 'dir.idx'); - const getIndexKeyFromFileKey = $$(getDirFomKey, dirIndex); - - const ifExists = (val, exists, notExists) => (fp.isUndefined(val) - ? fp.isUndefined(notExists) ? (() => { })() : notExists() - : exists()); - - const getOrDefault = (val, defaultVal) => ifExists(val, () => val, () => defaultVal); - - const not = func => val => !func(val); - const isDefined = not(fp.isUndefined); - const isNonNull = not(fp.isNull); - const isNotNaN = not(fp.isNaN); - - const allTrue = (...funcArgs) => val => fp.reduce( - (result, conditionFunc) => (fp.isNull(result) || result == true) && conditionFunc(val), - null)(funcArgs); - - const anyTrue = (...funcArgs) => val => fp.reduce( - (result, conditionFunc) => result == true || conditionFunc(val), - null)(funcArgs); - - const insensitiveEquals = (str1, str2) => str1.trim().toLowerCase() === str2.trim().toLowerCase(); - - const isSomething = allTrue(isDefined, isNonNull, isNotNaN); - const isNothing = not(isSomething); - const isNothingOrEmpty = v => isNothing(v) || fp.isEmpty(v); - const somethingOrGetDefault = getDefaultFunc => val => (isSomething(val) ? val : getDefaultFunc()); - const somethingOrDefault = (val, defaultVal) => somethingOrGetDefault(fp.constant(defaultVal))(val); - - const mapIfSomethingOrDefault = (mapFunc, defaultVal) => val => (isSomething(val) ? mapFunc(val) : defaultVal); - - const mapIfSomethingOrBlank = mapFunc => mapIfSomethingOrDefault(mapFunc, ''); - - const none = predicate => collection => !fp.some(predicate)(collection); - - const all = predicate => collection => none(v => !predicate(v))(collection); - - const isNotEmpty = ob => !fp.isEmpty(ob); - const isNonEmptyArray = allTrue(fp.isArray, isNotEmpty); - const isNonEmptyString = allTrue(fp.isString, isNotEmpty); - const tryOr = failFunc => (func, ...args) => { - try { - return func.apply(null, ...args); - } catch (_) { - return failFunc(); - } - }; - - const tryAwaitOr = failFunc => async (func, ...args) => { - try { - return await func.apply(null, ...args); - } catch (_) { - return await failFunc(); - } - }; - - const defineError = (func, errorPrefix) => { - try { - return func(); - } catch (err) { - err.message = `${errorPrefix} : ${err.message}`; - throw err; - } - }; - - const tryOrIgnore = tryOr(() => { }); - const tryAwaitOrIgnore = tryAwaitOr(async () => { }); - const causesException = (func) => { - try { - func(); - return false; - } catch (e) { - return true; - } - }; - - const executesWithoutException = func => !causesException(func); - - const handleErrorWith = returnValInError => tryOr(fp.constant(returnValInError)); - - const handleErrorWithUndefined = handleErrorWith(undefined); - - const switchCase = (...cases) => (value) => { - const nextCase = () => _.head(cases)[0](value); - const nextResult = () => _.head(cases)[1](value); - - if (fp.isEmpty(cases)) return; // undefined - if (nextCase() === true) return nextResult(); - return switchCase(..._.tail(cases))(value); - }; - - const isValue = val1 => val2 => (val1 === val2); - const isOneOf = (...vals) => val => fp.includes(val)(vals); - const defaultCase = fp.constant(true); - const memberMatches = (member, match) => obj => match(obj[member]); - - - const StartsWith = searchFor => searchIn => _.startsWith(searchIn, searchFor); - - const contains = val => array => (_.findIndex(array, v => v === val) > -1); - - const getHashCode = (s) => { - let hash = 0; let i; let char; let - l; - if (s.length == 0) return hash; - for (i = 0, l = s.length; i < l; i++) { - char = s.charCodeAt(i); - hash = ((hash << 5) - hash) + char; - hash |= 0; // Convert to 32bit integer - } - - // converting to string, but dont want a "-" prefixed - if (hash < 0) { return `n${(hash * -1).toString()}`; } - return hash.toString(); - }; - - // thanks to https://blog.grossman.io/how-to-write-async-await-without-try-catch-blocks-in-javascript/ - const awEx = async (promise) => { - try { - const result = await promise; - return [undefined, result]; - } catch (error) { - return [error, undefined]; - } - }; - - const isSafeInteger = n => fp.isInteger(n) - && n <= Number.MAX_SAFE_INTEGER - && n >= 0 - Number.MAX_SAFE_INTEGER; - - const toDateOrNull = s => (fp.isNull(s) ? null - : fp.isDate(s) ? s : new Date(s)); - const toBoolOrNull = s => (fp.isNull(s) ? null - : s === 'true' || s === true); - const toNumberOrNull = s => (fp.isNull(s) ? null - : fp.toNumber(s)); - - const isArrayOfString = opts => fp.isArray(opts) && all(fp.isString)(opts); - - const pushAll = (target, items) => { - for(let i of items) target.push(i); - }; - - const pause = async duration => new Promise(res => setTimeout(res, duration)); - - const retry = async (fn, retries, delay, ...args) => { - try { - return await fn(...args); - } catch (err) { - if (retries > 1) { - return await pause(delay).then(async () => await retry(fn, (retries - 1), delay, ...args)); - } - throw err; - } - }; - - var index = { - ifExists, - getOrDefault, - isDefined, - isNonNull, - isNotNaN, - allTrue, - isSomething, - mapIfSomethingOrDefault, - mapIfSomethingOrBlank, - configFolder, - fieldDefinitions, - isNothing, - not, - switchCase, - defaultCase, - StartsWith, - contains, - templateDefinitions, - handleErrorWith, - handleErrorWithUndefined, - tryOr, - tryOrIgnore, - tryAwaitOr, - tryAwaitOrIgnore, - dirIndex, - keySep, - $, - $$, - getDirFomKey, - getFileFromKey, - splitKey, - somethingOrDefault, - getIndexKeyFromFileKey, - joinKey, - somethingOrGetDefault, - appDefinitionFile, - isValue, - all, - isOneOf, - memberMatches, - defineError, - anyTrue, - isNonEmptyArray, - causesException, - executesWithoutException, - none, - getHashCode, - awEx, - apiWrapper, - events, - eventsList, - isNothingOrEmpty, - isSafeInteger, - toNumber: fp.toNumber, - toDate: toDateOrNull, - toBool: toBoolOrNull, - isArrayOfString, - getLock, - NO_LOCK, - isNolock, - insensitiveEquals, - pause, - retry, - pushAll - }; - - const stringNotEmpty = s => isSomething(s) && s.trim().length > 0; - - const makerule = (field, error, isValid) => ({ field, error, isValid }); - - const validationError = (rule, item) => ({ ...rule, item }); - - const applyRuleSet = ruleSet => itemToValidate => $(ruleSet, [ - fp.map(applyRule(itemToValidate)), - fp.filter(isSomething), - ]); - - const applyRule = itemTovalidate => rule => (rule.isValid(itemTovalidate) - ? null - : validationError(rule, itemTovalidate)); - - const filterEval = 'FILTER_EVALUATE'; - const filterCompile = 'FILTER_COMPILE'; - const mapEval = 'MAP_EVALUATE'; - const mapCompile = 'MAP_COMPILE'; - - - const getEvaluateResult = () => ({ - isError: false, - passedFilter: true, - result: null, - }); - - const compileFilter = index => compilerUtil.compileExpression(index.filter); - - const compileMap = index => compilerUtil.compileCode(index.map); - - const passesFilter = (record, index) => { - const context = { record }; - if (!index.filter) return true; - - const compiledFilter = defineError( - () => compileFilter(index), - filterCompile, - ); - - return defineError( - () => compiledFilter(context), - filterEval, - ); - }; - - const mapRecord = (record, index) => { - const recordClone = fp.cloneDeep(record); - const context = { record: recordClone }; - - const map = index.map ? index.map : 'return {...record};'; - - const compiledMap = defineError( - () => compilerUtil.compileCode(map), - mapCompile, - ); - - const mapped = defineError( - () => compiledMap(context), - mapEval, - ); - - const mappedKeys = fp.keys(mapped); - for (let i = 0; i < mappedKeys.length; i++) { - const key = mappedKeys[i]; - mapped[key] = fp.isUndefined(mapped[key]) ? null : mapped[key]; - if (fp.isFunction(mapped[key])) { - delete mapped[key]; - } - } - - mapped.key = record.key; - mapped.sortKey = index.getSortKey - ? compilerUtil.compileCode(index.getSortKey)(context) - : record.id; - - return mapped; - }; - - const evaluate = record => (index) => { - const result = getEvaluateResult(); - - try { - result.passedFilter = passesFilter(record, index); - } catch (err) { - result.isError = true; - result.passedFilter = false; - result.result = err.message; - } - - if (!result.passedFilter) return result; - - try { - result.result = mapRecord(record, index); - } catch (err) { - result.isError = true; - result.result = err.message; - } - - return result; - }; - - const indexTypes = { reference: 'reference', ancestor: 'ancestor' }; - - const indexRuleSet = [ - makerule('map', 'index has no map function', - index => isNonEmptyString(index.map)), - makerule('map', "index's map function does not compile", - index => !isNonEmptyString(index.map) - || executesWithoutException(() => compileMap(index))), - makerule('filter', "index's filter function does not compile", - index => !isNonEmptyString(index.filter) - || executesWithoutException(() => compileFilter(index))), - makerule('name', 'must declare a name for index', - index => isNonEmptyString(index.name)), - makerule('name', 'there is a duplicate named index on this node', - index => fp.isEmpty(index.name) - || fp.countBy('name')(index.parent().indexes)[index.name] === 1), - makerule('indexType', 'reference index may only exist on a record node', - index => isRecord(index.parent()) - || index.indexType !== indexTypes.reference), - makerule('indexType', `index type must be one of: ${fp.join(', ')(fp.keys(indexTypes))}`, - index => fp.includes(index.indexType)(fp.keys(indexTypes))), - ]; - - const getFlattenedHierarchy = (appHierarchy, useCached = true) => { - if (isSomething(appHierarchy.getFlattenedHierarchy) && useCached) { return appHierarchy.getFlattenedHierarchy(); } - - const flattenHierarchy = (currentNode, flattened) => { - flattened.push(currentNode); - if ((!currentNode.children - || currentNode.children.length === 0) - && (!currentNode.indexes - || currentNode.indexes.length === 0) - && (!currentNode.aggregateGroups - || currentNode.aggregateGroups.length === 0)) { - return flattened; - } - - const unionIfAny = l2 => l1 => fp.union(l1)(!l2 ? [] : l2); - - const children = $([], [ - unionIfAny(currentNode.children), - unionIfAny(currentNode.indexes), - unionIfAny(currentNode.aggregateGroups), - ]); - - for (const child of children) { - flattenHierarchy(child, flattened); - } - return flattened; - }; - - appHierarchy.getFlattenedHierarchy = () => flattenHierarchy(appHierarchy, []); - return appHierarchy.getFlattenedHierarchy(); - }; - - const getLastPartInKey = key => fp.last(splitKey(key)); - - const getNodesInPath = appHierarchy => key => $(appHierarchy, [ - getFlattenedHierarchy, - fp.filter(n => new RegExp(`${n.pathRegx()}`).test(key)), - ]); - - const getExactNodeForKey = appHierarchy => key => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => new RegExp(`${n.pathRegx()}$`).test(key)), - ]); - - const getNodeForCollectionPath = appHierarchy => collectionKey => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => (isCollectionRecord(n) - && new RegExp(`${n.collectionPathRegx()}$`).test(collectionKey))), - ]); - - const hasMatchingAncestor = ancestorPredicate => decendantNode => switchCase( - - [node => isNothing(node.parent()), - fp.constant(false)], - - [node => ancestorPredicate(node.parent()), - fp.constant(true)], - - [defaultCase, - node => hasMatchingAncestor(ancestorPredicate)(node.parent())], - - )(decendantNode); - - const getNode = (appHierarchy, nodeKey) => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => n.nodeKey() === nodeKey - || (isCollectionRecord(n) - && n.collectionNodeKey() === nodeKey)), - ]); - - const getCollectionNode = (appHierarchy, nodeKey) => $(appHierarchy, [ - getFlattenedHierarchy, - fp.find(n => (isCollectionRecord(n) - && n.collectionNodeKey() === nodeKey)), - ]); - - const getNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => { - const nodeByKey = getExactNodeForKey(appHierarchy)(keyOrNodeKey); - return isNothing(nodeByKey) - ? getNode(appHierarchy, keyOrNodeKey) - : nodeByKey; - }; - - const getCollectionNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => { - const nodeByKey = getNodeForCollectionPath(appHierarchy)(keyOrNodeKey); - return isNothing(nodeByKey) - ? getCollectionNode(appHierarchy, keyOrNodeKey) - : nodeByKey; - }; - - const isNode = (appHierarchy, key) => isSomething(getExactNodeForKey(appHierarchy)(key)); - - const getActualKeyOfParent = (parentNodeKey, actualChildKey) => - $(actualChildKey, [ - splitKey, - fp.take(splitKey(parentNodeKey).length), - ks => joinKey(...ks), - ]); - - const getParentKey = (key) => { - return $(key, [ - splitKey, - fp.take(splitKey(key).length - 1), - joinKey, - ]); - }; - - const isKeyAncestorOf = ancestorKey => decendantNode => hasMatchingAncestor(p => p.nodeKey() === ancestorKey)(decendantNode); - - const hasNoMatchingAncestors = parentPredicate => node => !hasMatchingAncestor(parentPredicate)(node); - - const findField = (recordNode, fieldName) => fp.find(f => f.name == fieldName)(recordNode.fields); - - const isAncestor = decendant => ancestor => isKeyAncestorOf(ancestor.nodeKey())(decendant); - - const isDecendant = ancestor => decendant => isAncestor(decendant)(ancestor); - - const getRecordNodeId = recordKey => $(recordKey, [ - splitKey, - fp.last, - getRecordNodeIdFromId, - ]); - - const getRecordNodeIdFromId = recordId => $(recordId, [fp.split('-'), fp.first, parseInt]); - - const getRecordNodeById = (hierarchy, recordId) => $(hierarchy, [ - getFlattenedHierarchy, - fp.find(n => isRecord(n) - && n.nodeId === getRecordNodeIdFromId(recordId)), - ]); - - const recordNodeIdIsAllowed = indexNode => nodeId => indexNode.allowedRecordNodeIds.length === 0 - || fp.includes(nodeId)(indexNode.allowedRecordNodeIds); - - const recordNodeIsAllowed = indexNode => recordNode => recordNodeIdIsAllowed(indexNode)(recordNode.nodeId); - - const getAllowedRecordNodesForIndex = (appHierarchy, indexNode) => { - const recordNodes = $(appHierarchy, [ - getFlattenedHierarchy, - fp.filter(isRecord), - ]); - - if (isGlobalIndex(indexNode)) { - return $(recordNodes, [ - fp.filter(recordNodeIsAllowed(indexNode)), - ]); - } - - if (isAncestorIndex(indexNode)) { - return $(recordNodes, [ - fp.filter(isDecendant(indexNode.parent())), - fp.filter(recordNodeIsAllowed(indexNode)), - ]); - } - - if (isReferenceIndex(indexNode)) { - return $(recordNodes, [ - fp.filter(n => fp.some(fieldReversesReferenceToIndex(indexNode))(n.fields)), - ]); - } - }; - - const getNodeFromNodeKeyHash = hierarchy => hash => $(hierarchy, [ - getFlattenedHierarchy, - fp.find(n => getHashCode(n.nodeKey()) === hash), - ]); - - const isRecord = node => isSomething(node) && node.type === 'record'; - const isSingleRecord = node => isRecord(node) && node.isSingle; - const isCollectionRecord = node => isRecord(node) && !node.isSingle; - const isIndex = node => isSomething(node) && node.type === 'index'; - const isaggregateGroup = node => isSomething(node) && node.type === 'aggregateGroup'; - const isShardedIndex = node => isIndex(node) && isNonEmptyString(node.getShardName); - const isRoot = node => isSomething(node) && node.isRoot(); - const isDecendantOfARecord = hasMatchingAncestor(isRecord); - const isGlobalIndex = node => isIndex(node) && isRoot(node.parent()); - const isReferenceIndex = node => isIndex(node) && node.indexType === indexTypes.reference; - const isAncestorIndex = node => isIndex(node) && node.indexType === indexTypes.ancestor; - - const fieldReversesReferenceToNode = node => field => field.type === 'reference' - && fp.intersection(field.typeOptions.reverseIndexNodeKeys)(fp.map(i => i.nodeKey())(node.indexes)) - .length > 0; - - const fieldReversesReferenceToIndex = indexNode => field => field.type === 'reference' - && fp.intersection(field.typeOptions.reverseIndexNodeKeys)([indexNode.nodeKey()]) - .length > 0; - - var hierarchy = { - getLastPartInKey, - getNodesInPath, - getExactNodeForKey, - hasMatchingAncestor, - getNode, - getNodeByKeyOrNodeKey, - isNode, - getActualKeyOfParent, - getParentKey, - isKeyAncestorOf, - hasNoMatchingAncestors, - findField, - isAncestor, - isDecendant, - getRecordNodeId, - getRecordNodeIdFromId, - getRecordNodeById, - recordNodeIdIsAllowed, - recordNodeIsAllowed, - getAllowedRecordNodesForIndex, - getNodeFromNodeKeyHash, - isRecord, - isCollectionRecord, - isIndex, - isaggregateGroup, - isShardedIndex, - isRoot, - isDecendantOfARecord, - isGlobalIndex, - isReferenceIndex, - isAncestorIndex, - fieldReversesReferenceToNode, - fieldReversesReferenceToIndex, - getFlattenedHierarchy, - }; - - const getSafeFieldParser = (tryParse, defaultValueFunctions) => (field, record) => { - if (fp.has(field.name)(record)) { - return getSafeValueParser(tryParse, defaultValueFunctions)(record[field.name]); - } - return defaultValueFunctions[field.getUndefinedValue](); - }; - - const getSafeValueParser = (tryParse, defaultValueFunctions) => (value) => { - const parsed = tryParse(value); - if (parsed.success) { - return parsed.value; - } - return defaultValueFunctions.default(); - }; - - const getNewValue = (tryParse, defaultValueFunctions) => (field) => { - const getInitialValue = fp.isUndefined(field) || fp.isUndefined(field.getInitialValue) - ? 'default' - : field.getInitialValue; - - return fp.has(getInitialValue)(defaultValueFunctions) - ? defaultValueFunctions[getInitialValue]() - : getSafeValueParser(tryParse, defaultValueFunctions)(getInitialValue); - }; - - const typeFunctions = specificFunctions => _.merge({ - value: fp.constant, - null: fp.constant(null), - }, specificFunctions); - - const validateTypeConstraints = validationRules => async (field, record, context) => { - const fieldValue = record[field.name]; - const validateRule = async r => (!await r.isValid(fieldValue, field.typeOptions, context) - ? r.getMessage(fieldValue, field.typeOptions) - : ''); - - const errors = []; - for (const r of validationRules) { - const err = await validateRule(r); - if (isNotEmpty(err)) errors.push(err); - } - - return errors; - }; - - const getDefaultOptions = fp.mapValues(v => v.defaultValue); - - const makerule$1 = (isValid, getMessage) => ({ isValid, getMessage }); - const parsedFailed = val => ({ success: false, value: val }); - const parsedSuccess = val => ({ success: true, value: val }); - const getDefaultExport = (name, tryParse, functions, options, validationRules, sampleValue, stringify) => ({ - getNew: getNewValue(tryParse, functions), - safeParseField: getSafeFieldParser(tryParse, functions), - safeParseValue: getSafeValueParser(tryParse, functions), - tryParse, - name, - getDefaultOptions: () => getDefaultOptions(fp.cloneDeep(options)), - optionDefinitions: options, - validateTypeConstraints: validateTypeConstraints(validationRules), - sampleValue, - stringify: val => (val === null || val === undefined - ? '' : stringify(val)), - getDefaultValue: functions.default, - }); - - const stringFunctions = typeFunctions({ - default: fp.constant(null), - }); - - const stringTryParse = switchCase( - [fp.isString, parsedSuccess], - [fp.isNull, parsedSuccess], - [defaultCase, v => parsedSuccess(v.toString())], - ); - - const options = { - maxLength: { - defaultValue: null, - isValid: n => n === null || isSafeInteger(n) && n > 0, - requirementDescription: 'max length must be null (no limit) or a greater than zero integer', - parse: toNumberOrNull, - }, - values: { - defaultValue: null, - isValid: v => v === null || (isArrayOfString(v) && v.length > 0 && v.length < 10000), - requirementDescription: "'values' must be null (no values) or an arry of at least one string", - parse: s => s, - }, - allowDeclaredValuesOnly: { - defaultValue: false, - isValid: fp.isBoolean, - requirementDescription: 'allowDeclaredValuesOnly must be true or false', - parse: toBoolOrNull, - }, - }; - - const typeConstraints = [ - makerule$1(async (val, opts) => val === null || opts.maxLength === null || val.length <= opts.maxLength, - (val, opts) => `value exceeds maximum length of ${opts.maxLength}`), - makerule$1(async (val, opts) => val === null - || opts.allowDeclaredValuesOnly === false - || fp.includes(val)(opts.values), - (val) => `"${val}" does not exist in the list of allowed values`), - ]; - - var string = getDefaultExport( - 'string', - stringTryParse, - stringFunctions, - options, - typeConstraints, - 'abcde', - str => str, - ); - - const boolFunctions = typeFunctions({ - default: fp.constant(null), - }); - - const boolTryParse = switchCase( - [fp.isBoolean, parsedSuccess], - [fp.isNull, parsedSuccess], - [isOneOf('true', '1', 'yes', 'on'), () => parsedSuccess(true)], - [isOneOf('false', '0', 'no', 'off'), () => parsedSuccess(false)], - [defaultCase, parsedFailed], - ); - - const options$1 = { - allowNulls: { - defaultValue: true, - isValid: fp.isBoolean, - requirementDescription: 'must be a true or false', - parse: toBoolOrNull, - }, - }; - - const typeConstraints$1 = [ - makerule$1(async (val, opts) => opts.allowNulls === true || val !== null, - () => 'field cannot be null'), - ]; - - var bool = getDefaultExport( - 'bool', boolTryParse, boolFunctions, - options$1, typeConstraints$1, true, JSON.stringify, - ); - - const numberFunctions = typeFunctions({ - default: fp.constant(null), - }); - - const parseStringtoNumberOrNull = (s) => { - const num = Number(s); - return isNaN(num) ? parsedFailed(s) : parsedSuccess(num); - }; - - const numberTryParse = switchCase( - [fp.isNumber, parsedSuccess], - [fp.isString, parseStringtoNumberOrNull], - [fp.isNull, parsedSuccess], - [defaultCase, parsedFailed], - ); - - const options$2 = { - maxValue: { - defaultValue: Number.MAX_SAFE_INTEGER, - isValid: isSafeInteger, - requirementDescription: 'must be a valid integer', - parse: toNumberOrNull, - }, - minValue: { - defaultValue: 0 - Number.MAX_SAFE_INTEGER, - isValid: isSafeInteger, - requirementDescription: 'must be a valid integer', - parse: toNumberOrNull, - }, - decimalPlaces: { - defaultValue: 0, - isValid: n => isSafeInteger(n) && n >= 0, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, - }; - - const getDecimalPlaces = (val) => { - const splitDecimal = val.toString().split('.'); - if (splitDecimal.length === 1) return 0; - return splitDecimal[1].length; - }; - - const typeConstraints$2 = [ - makerule$1(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue, - (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`), - makerule$1(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue, - (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`), - makerule$1(async (val, opts) => val === null || opts.decimalPlaces >= getDecimalPlaces(val), - (val, opts) => `value (${val.toString()}) must have ${opts.decimalPlaces} decimal places or less`), - ]; - - var number = getDefaultExport( - 'number', - numberTryParse, - numberFunctions, - options$2, - typeConstraints$2, - 1, - num => num.toString(), - ); - - const dateFunctions = typeFunctions({ - default: fp.constant(null), - now: () => new Date(), - }); - - const isValidDate = d => d instanceof Date && !isNaN(d); - - const parseStringToDate = s => switchCase( - [isValidDate, parsedSuccess], - [defaultCase, parsedFailed], - )(new Date(s)); - - - const dateTryParse = switchCase( - [fp.isDate, parsedSuccess], - [fp.isString, parseStringToDate], - [fp.isNull, parsedSuccess], - [defaultCase, parsedFailed], - ); - - const options$3 = { - maxValue: { - defaultValue: new Date(32503680000000), - isValid: fp.isDate, - requirementDescription: 'must be a valid date', - parse: toDateOrNull, - }, - minValue: { - defaultValue: new Date(-8520336000000), - isValid: fp.isDate, - requirementDescription: 'must be a valid date', - parse: toDateOrNull, - }, - }; - - const typeConstraints$3 = [ - makerule$1(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue, - (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`), - makerule$1(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue, - (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`), - ]; - - var datetime = getDefaultExport( - 'datetime', - dateTryParse, - dateFunctions, - options$3, - typeConstraints$3, - new Date(1984, 4, 1), - date => JSON.stringify(date).replace(new RegExp('"', 'g'), ''), - ); - - const arrayFunctions = () => typeFunctions({ - default: fp.constant([]), - }); - - const mapToParsedArrary = type => $$( - fp.map(i => type.safeParseValue(i)), - parsedSuccess, - ); - - const arrayTryParse = type => switchCase( - [fp.isArray, mapToParsedArrary(type)], - [defaultCase, parsedFailed], - ); - - const typeName = type => `array<${type}>`; - - - const options$4 = { - maxLength: { - defaultValue: 10000, - isValid: isSafeInteger, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, - minLength: { - defaultValue: 0, - isValid: n => isSafeInteger(n) && n >= 0, - requirementDescription: 'must be a positive integer', - parse: toNumberOrNull, - }, - }; - - const typeConstraints$4 = [ - makerule$1(async (val, opts) => val === null || val.length >= opts.minLength, - (val, opts) => `must choose ${opts.minLength} or more options`), - makerule$1(async (val, opts) => val === null || val.length <= opts.maxLength, - (val, opts) => `cannot choose more than ${opts.maxLength} options`), - ]; - - var array = type => getDefaultExport( - typeName(type.name), - arrayTryParse(type), - arrayFunctions(), - options$4, - typeConstraints$4, - [type.sampleValue], - JSON.stringify, - ); - - const referenceNothing = () => ({ key: '' }); - - const referenceFunctions = typeFunctions({ - default: referenceNothing, - }); - - const hasStringValue = (ob, path) => fp.has(path)(ob) - && fp.isString(ob[path]); - - const isObjectWithKey = v => fp.isObjectLike(v) - && hasStringValue(v, 'key'); - - const tryParseFromString = s => { - - try { - const asObj = JSON.parse(s); - if(isObjectWithKey) { - return parsedSuccess(asObj); - } - } - catch(_) { - // EMPTY - } - - return parsedFailed(s); - }; - - const referenceTryParse = v => switchCase( - [isObjectWithKey, parsedSuccess], - [fp.isString, tryParseFromString], - [fp.isNull, () => parsedSuccess(referenceNothing())], - [defaultCase, parsedFailed], - )(v); - - const options$5 = { - indexNodeKey: { - defaultValue: null, - isValid: isNonEmptyString, - requirementDescription: 'must be a non-empty string', - parse: s => s, - }, - displayValue: { - defaultValue: '', - isValid: isNonEmptyString, - requirementDescription: 'must be a non-empty string', - parse: s => s, - }, - reverseIndexNodeKeys: { - defaultValue: null, - isValid: v => isArrayOfString(v) && v.length > 0, - requirementDescription: 'must be a non-empty array of strings', - parse: s => s, - }, - }; - - const isEmptyString = s => fp.isString(s) && fp.isEmpty(s); - - const ensureReferenceExists = async (val, opts, context) => isEmptyString(val.key) - || await context.referenceExists(opts, val.key); - - const typeConstraints$5 = [ - makerule$1( - ensureReferenceExists, - (val, opts) => `"${val[opts.displayValue]}" does not exist in options list (key: ${val.key})`, - ), - ]; - - var reference = getDefaultExport( - 'reference', - referenceTryParse, - referenceFunctions, - options$5, - typeConstraints$5, - { key: 'key', value: 'value' }, - JSON.stringify, - ); - - const illegalCharacters = '*?\\/:<>|\0\b\f\v'; - - const isLegalFilename = (filePath) => { - const fn = fileName(filePath); - return fn.length <= 255 - && fp.intersection(fn.split(''))(illegalCharacters.split('')).length === 0 - && none(f => f === '..')(splitKey(filePath)); - }; - - const fileNothing = () => ({ relativePath: '', size: 0 }); - - const fileFunctions = typeFunctions({ - default: fileNothing, - }); - - const fileTryParse = v => switchCase( - [isValidFile, parsedSuccess], - [fp.isNull, () => parsedSuccess(fileNothing())], - [defaultCase, parsedFailed], - )(v); - - const fileName = filePath => $(filePath, [ - splitKey, - fp.last, - ]); - - const isValidFile = f => !fp.isNull(f) - && fp.has('relativePath')(f) && fp.has('size')(f) - && fp.isNumber(f.size) - && fp.isString(f.relativePath) - && isLegalFilename(f.relativePath); - - const options$6 = {}; - - const typeConstraints$6 = []; - - var file = getDefaultExport( - 'file', - fileTryParse, - fileFunctions, - options$6, - typeConstraints$6, - { relativePath: 'some_file.jpg', size: 1000 }, - JSON.stringify, - ); - - const allTypes = () => { - const basicTypes = { - string, number, datetime, bool, reference, file, - }; - - const arrays = $(basicTypes, [ - fp.keys, - fp.map((k) => { - const kvType = {}; - const concreteArray = array(basicTypes[k]); - kvType[concreteArray.name] = concreteArray; - return kvType; - }), - types => _.assign({}, ...types), - ]); - - return _.merge({}, basicTypes, arrays); - }; - - - const all$1 = allTypes(); - - const getType = (typeName) => { - if (!fp.has(typeName)(all$1)) throw new BadRequestError(`Do not recognise type ${typeName}`); - return all$1[typeName]; - }; - - const getSampleFieldValue = field => getType(field.type).sampleValue; - - const getNewFieldValue = field => getType(field.type).getNew(field); - - const safeParseField = (field, record) => getType(field.type).safeParseField(field, record); - - const validateFieldParse = (field, record) => (fp.has(field.name)(record) - ? getType(field.type).tryParse(record[field.name]) - : parsedSuccess(undefined)); // fields may be undefined by default - - const getDefaultOptions$1 = type => getType(type).getDefaultOptions(); - - const validateTypeConstraints$1 = async (field, record, context) => await getType(field.type).validateTypeConstraints(field, record, context); - - const detectType = (value) => { - if (fp.isString(value)) return string; - if (fp.isBoolean(value)) return bool; - if (fp.isNumber(value)) return number; - if (fp.isDate(value)) return datetime; - if (fp.isArray(value)) return array(detectType(value[0])); - if (fp.isObject(value) - && fp.has('key')(value) - && fp.has('value')(value)) return reference; - if (fp.isObject(value) - && fp.has('relativePath')(value) - && fp.has('size')(value)) return file; - - throw new BadRequestError(`cannot determine type: ${JSON.stringify(value)}`); - }; - - // 5 minutes - const tempCodeExpiryLength = 5 * 60 * 1000; - - const AUTH_FOLDER = '/.auth'; - const USERS_LIST_FILE = joinKey(AUTH_FOLDER, 'users.json'); - const userAuthFile = username => joinKey(AUTH_FOLDER, `auth_${username}.json`); - const USERS_LOCK_FILE = joinKey(AUTH_FOLDER, 'users_lock'); - const ACCESS_LEVELS_FILE = joinKey(AUTH_FOLDER, 'access_levels.json'); - const ACCESS_LEVELS_LOCK_FILE = joinKey(AUTH_FOLDER, 'access_levels_lock'); - - const permissionTypes = { - CREATE_RECORD: 'create record', - UPDATE_RECORD: 'update record', - READ_RECORD: 'read record', - DELETE_RECORD: 'delete record', - READ_INDEX: 'read index', - MANAGE_INDEX: 'manage index', - MANAGE_COLLECTION: 'manage collection', - WRITE_TEMPLATES: 'write templates', - CREATE_USER: 'create user', - SET_PASSWORD: 'set password', - CREATE_TEMPORARY_ACCESS: 'create temporary access', - ENABLE_DISABLE_USER: 'enable or disable user', - WRITE_ACCESS_LEVELS: 'write access levels', - LIST_USERS: 'list users', - LIST_ACCESS_LEVELS: 'list access levels', - EXECUTE_ACTION: 'execute action', - SET_USER_ACCESS_LEVELS: 'set user access levels', - }; - - const getUserByName = (users, name) => $(users, [ - fp.find(u => u.name.toLowerCase() === name.toLowerCase()), - ]); - - const stripUserOfSensitiveStuff = (user) => { - const stripped = fp.clone(user); - delete stripped.tempCode; - return stripped; - }; - - const parseTemporaryCode = fullCode => $(fullCode, [ - fp.split(':'), - parts => ({ - id: parts[1], - code: parts[2], - }), - ]); - - const isAuthorized = app => (permissionType, resourceKey) => apiWrapperSync( - app, - events.authApi.isAuthorized, - alwaysAuthorized, - { resourceKey, permissionType }, - _isAuthorized, app, permissionType, resourceKey, - ); - - const _isAuthorized = (app, permissionType, resourceKey) => { - if (!app.user) { - return false; - } - - const validType = $(permissionTypes, [ - fp.values, - fp.includes(permissionType), - ]); - - if (!validType) { - return false; - } - - const permMatchesResource = (userperm) => { - const nodeKey = isNothing(resourceKey) - ? null - : isNode(app.hierarchy, resourceKey) - ? getNodeByKeyOrNodeKey( - app.hierarchy, resourceKey, - ).nodeKey() - : resourceKey; - - return (userperm.type === permissionType) - && ( - isNothing(resourceKey) - || nodeKey === userperm.nodeKey - ); - }; - - return $(app.user.permissions, [ - fp.some(permMatchesResource), - ]); - }; - - const nodePermission = type => ({ - add: (nodeKey, accessLevel) => accessLevel.permissions.push({ type, nodeKey }), - isAuthorized: resourceKey => app => isAuthorized(app)(type, resourceKey), - isNode: true, - get: nodeKey => ({ type, nodeKey }), - }); - - const staticPermission = type => ({ - add: accessLevel => accessLevel.permissions.push({ type }), - isAuthorized: app => isAuthorized(app)(type), - isNode: false, - get: () => ({ type }), - }); - - const createRecord = nodePermission(permissionTypes.CREATE_RECORD); - - const updateRecord = nodePermission(permissionTypes.UPDATE_RECORD); - - const deleteRecord = nodePermission(permissionTypes.DELETE_RECORD); - - const readRecord = nodePermission(permissionTypes.READ_RECORD); - - const writeTemplates = staticPermission(permissionTypes.WRITE_TEMPLATES); - - const createUser = staticPermission(permissionTypes.CREATE_USER); - - const setPassword = staticPermission(permissionTypes.SET_PASSWORD); - - const readIndex = nodePermission(permissionTypes.READ_INDEX); - - const manageIndex = staticPermission(permissionTypes.MANAGE_INDEX); - - const manageCollection = staticPermission(permissionTypes.MANAGE_COLLECTION); - - const createTemporaryAccess = staticPermission(permissionTypes.CREATE_TEMPORARY_ACCESS); - - const enableDisableUser = staticPermission(permissionTypes.ENABLE_DISABLE_USER); - - const writeAccessLevels = staticPermission(permissionTypes.WRITE_ACCESS_LEVELS); - - const listUsers = staticPermission(permissionTypes.LIST_USERS); - - const listAccessLevels = staticPermission(permissionTypes.LIST_ACCESS_LEVELS); - - const setUserAccessLevels = staticPermission(permissionTypes.SET_USER_ACCESS_LEVELS); - - const executeAction = nodePermission(permissionTypes.EXECUTE_ACTION); - - const alwaysAuthorized = () => true; - - const permission = { - createRecord, - updateRecord, - deleteRecord, - readRecord, - writeTemplates, - createUser, - setPassword, - readIndex, - createTemporaryAccess, - enableDisableUser, - writeAccessLevels, - listUsers, - listAccessLevels, - manageIndex, - manageCollection, - executeAction, - setUserAccessLevels, - }; - - const getNew = app => (collectionKey, recordTypeName) => { - const recordNode = getRecordNode(app, collectionKey); - collectionKey=safeKey(collectionKey); - return apiWrapperSync( - app, - events.recordApi.getNew, - permission.createRecord.isAuthorized(recordNode.nodeKey()), - { collectionKey, recordTypeName }, - _getNew, recordNode, collectionKey, - ); - }; - - const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey); - - const getRecordNode = (app, collectionKey) => { - collectionKey = safeKey(collectionKey); - return getNodeForCollectionPath(app.hierarchy)(collectionKey); - }; - - const getNewChild = app => (recordKey, collectionName, recordTypeName) => - getNew(app)(joinKey(recordKey, collectionName), recordTypeName); - - const constructRecord = (recordNode, getFieldValue, collectionKey) => { - const record = $(recordNode.fields, [ - fp.keyBy('name'), - fp.mapValues(getFieldValue), - ]); - - record.id = `${recordNode.nodeId}-${shortid.generate()}`; - record.key = isSingleRecord(recordNode) - ? joinKey(collectionKey, recordNode.name) - : joinKey(collectionKey, record.id); - record.isNew = true; - record.type = recordNode.name; - return record; - }; - - const allIdChars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_-'; - - // this should never be changed - ever - // - existing databases depend on the order of chars this string - - /** - * folderStructureArray should return an array like - * - [1] = all records fit into one folder - * - [2] = all records fite into 2 folders - * - [64, 3] = all records fit into 64 * 3 folders - * - [64, 64, 10] = all records fit into 64 * 64 * 10 folder - * (there are 64 possible chars in allIsChars) - */ - const folderStructureArray = (recordNode) => { - - const totalFolders = Math.ceil(recordNode.estimatedRecordCount / 1000); - const folderArray = []; - let levelCount = 1; - while(64**levelCount < totalFolders) { - levelCount += 1; - folderArray.push(64); - } - - const parentFactor = (64**folderArray.length); - if(parentFactor < totalFolders) { - folderArray.push( - Math.ceil(totalFolders / parentFactor) - ); - } - - return folderArray; - - /* - const maxRecords = currentFolderPosition === 0 - ? RECORDS_PER_FOLDER - : currentFolderPosition * 64 * RECORDS_PER_FOLDER; - - if(maxRecords < recordNode.estimatedRecordCount) { - return folderStructureArray( - recordNode, - [...currentArray, 64], - currentFolderPosition + 1); - } else { - const childFolderCount = Math.ceil(recordNode.estimatedRecordCount / maxRecords ); - return [...currentArray, childFolderCount] - }*/ - }; - - - const getAllIdsIterator = app => async (collection_Key_or_NodeKey) => { - collection_Key_or_NodeKey = safeKey(collection_Key_or_NodeKey); - const recordNode = getCollectionNodeByKeyOrNodeKey( - app.hierarchy, - collection_Key_or_NodeKey, - ); - - const getAllIdsIteratorForCollectionKey = async (recordNode, collectionKey) => { - - const folderStructure = folderStructureArray(recordNode); - - let currentFolderContents = []; - let currentPosition = []; - - const collectionDir = getCollectionDir(app.hierarchy, collectionKey); - const basePath = joinKey( - collectionDir, recordNode.nodeId.toString()); - - - - // "folderStructure" determines the top, sharding folders - // we need to add one, for the collection root folder, which - // always exists - const levels = folderStructure.length + 1; - const topLevel = levels -1; - - - /* populate initial directory structure in form: - [ - {path: "/a", contents: ["b", "c", "d"]}, - {path: "/a/b", contents: ["e","f","g"]}, - {path: "/a/b/e", contents: ["1-abcd","2-cdef","3-efgh"]}, - ] - // stores contents on each parent level - // top level has ID folders - */ - const firstFolder = async () => { - - let folderLevel = 0; - - const lastPathHasContent = () => - folderLevel === 0 - || currentFolderContents[folderLevel - 1].contents.length > 0; - - - while (folderLevel <= topLevel && lastPathHasContent()) { - - let thisPath = basePath; - for(let lev = 0; lev < currentPosition.length; lev++) { - thisPath = joinKey( - thisPath, currentFolderContents[lev].contents[0]); - } - - const contentsThisLevel = - await app.datastore.getFolderContents(thisPath); - currentFolderContents.push({ - contents:contentsThisLevel, - path: thisPath - }); - - // should start as something like [0,0] - if(folderLevel < topLevel) - currentPosition.push(0); - - folderLevel+=1; - } - - return (currentPosition.length === levels - 1); - }; - - const isOnLastFolder = level => { - - const result = currentPosition[level] === currentFolderContents[level].contents.length - 1; - return result; - }; - - const getNextFolder = async (lev=undefined) => { - lev = fp.isUndefined(lev) ? topLevel : lev; - const parentLev = lev - 1; - - if(parentLev < 0) return false; - - if(isOnLastFolder(parentLev)) { - return await getNextFolder(parentLev); - } - - const newPosition = currentPosition[parentLev] + 1; - currentPosition[parentLev] = newPosition; - - const nextFolder = joinKey( - currentFolderContents[parentLev].path, - currentFolderContents[parentLev].contents[newPosition]); - currentFolderContents[lev].contents = await app.datastore.getFolderContents( - nextFolder - ); - currentFolderContents[lev].path = nextFolder; - - if(lev !== topLevel) { - - // we just advanced a parent folder, so now need to - // do the same to the next levels - let loopLevel = lev + 1; - while(loopLevel <= topLevel) { - const loopParentLevel = loopLevel-1; - - currentPosition[loopParentLevel] = 0; - const nextLoopFolder = joinKey( - currentFolderContents[loopParentLevel].path, - currentFolderContents[loopParentLevel].contents[0]); - currentFolderContents[loopLevel].contents = await app.datastore.getFolderContents( - nextLoopFolder - ); - currentFolderContents[loopLevel].path = nextLoopFolder; - loopLevel+=1; - } - } - - // true ==has more ids... (just loaded more) - return true; - }; - - - const idsCurrentFolder = () => - currentFolderContents[currentFolderContents.length - 1].contents; - - const fininshedResult = ({ done: true, result: { ids: [], collectionKey } }); - - let hasStarted = false; - let hasMore = true; - const getIdsFromCurrentfolder = async () => { - - if(!hasMore) { - return fininshedResult; - } - - if(!hasStarted) { - hasMore = await firstFolder(); - hasStarted = true; - return ({ - result: { - ids: idsCurrentFolder(), - collectionKey - }, - done: false - }) - } - - hasMore = await getNextFolder(); - - return ({ - result: { - ids: hasMore ? idsCurrentFolder() : [], - collectionKey - }, - done: !hasMore - }); - }; - - return getIdsFromCurrentfolder; - - }; - - const ancestors = $(getFlattenedHierarchy(app.hierarchy), [ - fp.filter(isCollectionRecord), - fp.filter(n => isAncestor(recordNode)(n) - || n.nodeKey() === recordNode.nodeKey()), - fp.orderBy([n => n.nodeKey().length], ['asc']), - ]); // parents first - - const traverseForIteraterators = async (parentRecordKey = '', currentNodeIndex = 0) => { - const currentNode = ancestors[currentNodeIndex]; - const currentCollectionKey = joinKey( - parentRecordKey, - currentNode.collectionName, - ); - if (currentNode.nodeKey() === recordNode.nodeKey()) { - return [ - await getAllIdsIteratorForCollectionKey( - currentNode, - currentCollectionKey, - )]; - } - const allIterators = []; - const currentIterator = await getAllIdsIteratorForCollectionKey( - currentNode, - currentCollectionKey, - ); - - let ids = await currentIterator(); - while (ids.done === false) { - for (const id of ids.result.ids) { - allIterators.push( - await traverseForIteraterators( - joinKey(currentCollectionKey, id), - currentNodeIndex + 1, - ), - ); - } - - ids = await currentIterator(); - } - - return fp.flatten(allIterators); - }; - - const iteratorsArray = await traverseForIteraterators(); - let currentIteratorIndex = 0; - return async () => { - if (iteratorsArray.length === 0) { return { done: true, result: [] }; } - const innerResult = await iteratorsArray[currentIteratorIndex](); - if (!innerResult.done) { return innerResult; } - if (currentIteratorIndex == iteratorsArray.length - 1) { - return { done: true, result: innerResult.result }; - } - currentIteratorIndex++; - return { done: false, result: innerResult.result }; - }; - }; - - const getRecordInfo = (hierarchy, key) => { - const recordNode = getExactNodeForKey(hierarchy)(key); - const pathInfo = getRecordDirectory(recordNode, key); - const dir = joinKey(pathInfo.base, ...pathInfo.subdirs); - - return { - recordJson: recordJson(dir), - files: files(dir), - child:(name) => joinKey(dir, name), - key: safeKey(key), - recordNode, pathInfo, dir - }; - }; - - const getCollectionDir = (hierarchy, collectionKey) => { - const recordNode = getNodeForCollectionPath(hierarchy)(collectionKey); - const dummyRecordKey = joinKey(collectionKey, "1-abcd"); - const pathInfo = getRecordDirectory(recordNode, dummyRecordKey); - return pathInfo.base; - }; - - const recordJson = (dir) => - joinKey(dir, "record.json"); - - const files = (dir) => - joinKey(dir, "files"); - - const getRecordDirectory = (recordNode, key) => { - const id = getFileFromKey(key); - - const traverseParentKeys = (n, parents=[]) => { - if(isRoot(n)) return parents; - const k = getActualKeyOfParent(n.nodeKey(), key); - const thisNodeDir = { - node:n, - relativeDir: joinKey( - recordRelativeDirectory(n, getFileFromKey(k))) - }; - return traverseParentKeys( - n.parent(), - [thisNodeDir, ...parents]); - }; - - const parentDirs = $(recordNode.parent(), [ - traverseParentKeys, - fp.reduce((key, item) => { - return joinKey(key, item.node.collectionName, item.relativeDir) - }, keySep) - ]); - - const subdirs = isSingleRecord(recordNode) - ? [] - : recordRelativeDirectory(recordNode, id); - const base = isSingleRecord(recordNode) - ? joinKey(parentDirs, recordNode.name) - : joinKey(parentDirs, recordNode.collectionName); - - return ({ - subdirs, base - }); - }; - - const recordRelativeDirectory = (recordNode, id) => { - const folderStructure = folderStructureArray(recordNode); - const strippedId = id.substring(recordNode.nodeId.toString().length + 1); - const subfolders = $(folderStructure, [ - fp.reduce((result, currentCount) => { - result.folders.push( - folderForChar(strippedId[result.level], currentCount) - ); - return {level:result.level+1, folders:result.folders}; - }, {level:0, folders:[]}), - f => f.folders, - fp.filter(f => !!f) - ]); - - return [recordNode.nodeId.toString(), ...subfolders, id] - }; - - const folderForChar = (char, folderCount) => - folderCount === 1 ? "" - : $(folderCount, [ - idFoldersForFolderCount, - fp.find(f => f.includes(char)) - ]); - - const idFoldersForFolderCount = (folderCount) => { - const charRangePerShard = 64 / folderCount; - const idFolders = []; - let index = 0; - let currentIdsShard = ''; - while (index < 64) { - currentIdsShard += allIdChars[index]; - if ((index + 1) % charRangePerShard === 0) { - idFolders.push(currentIdsShard); - currentIdsShard = ''; - } - index++; - } - - return idFolders; - }; - - const load = app => async key => { - key = safeKey(key); - return apiWrapper( - app, - events.recordApi.load, - permission.readRecord.isAuthorized(key), - { key }, - _load, app, key, - ); - }; - - const _loadFromInfo = async (app, recordInfo, keyStack = []) => { - const key = recordInfo.key; - const {recordNode, recordJson} = recordInfo; - const storedData = await app.datastore.loadJson(recordJson); - - const loadedRecord = $(recordNode.fields, [ - fp.keyBy('name'), - fp.mapValues(f => safeParseField(f, storedData)), - ]); - - const newKeyStack = [...keyStack, key]; - - const references = $(recordNode.fields, [ - fp.filter(f => f.type === 'reference' - && isNonEmptyString(loadedRecord[f.name].key) - && !fp.includes(loadedRecord[f.name].key)(newKeyStack)), - fp.map(f => ({ - promise: _load(app, loadedRecord[f.name].key, newKeyStack), - index: getNode(app.hierarchy, f.typeOptions.indexNodeKey), - field: f, - })), - ]); - - if (references.length > 0) { - const refRecords = await Promise.all( - fp.map(p => p.promise)(references), - ); - - for (const ref of references) { - loadedRecord[ref.field.name] = mapRecord( - refRecords[references.indexOf(ref)], - ref.index, - ); - } - } - - loadedRecord.transactionId = storedData.transactionId; - loadedRecord.isNew = false; - loadedRecord.key = key; - loadedRecord.id = $(key, [splitKey, fp.last]); - loadedRecord.type = recordNode.name; - return loadedRecord; - }; - - const _load = async (app, key, keyStack = []) => - _loadFromInfo( - app, - getRecordInfo(app.hierarchy, key), - keyStack); - - // adapted from https://github.com/dex4er/js-promise-readable - // thanks :) - - const promiseReadableStream = stream => { - - let _errored; - - const _errorHandler = err => { - _errored = err; - }; - - stream.on("error", _errorHandler); - - const read = (size) => { - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err) - } - - if (!stream.readable || stream.closed || stream.destroyed) { - return resolve(); - } - - const readableHandler = () => { - const chunk = stream.read(size); - - if (chunk) { - removeListeners(); - resolve(chunk); - } - }; - - const closeHandler = () => { - removeListeners(); - resolve(); - }; - - const endHandler = () => { - removeListeners(); - resolve(); - }; - - const errorHandler = (err) => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const removeListeners = () => { - stream.removeListener("close", closeHandler); - stream.removeListener("error", errorHandler); - stream.removeListener("end", endHandler); - stream.removeListener("readable", readableHandler); - }; - - stream.on("close", closeHandler); - stream.on("end", endHandler); - stream.on("error", errorHandler); - stream.on("readable", readableHandler); - - readableHandler(); - }); - }; - - - const destroy = () => { - if (stream) { - if (_errorHandler) { - stream.removeListener("error", _errorHandler); - } - if (typeof stream.destroy === "function") { - stream.destroy(); - } - } - }; - - return {read, destroy, stream}; - }; - - const getIndexedDataKey = (indexNode, indexDir, record) => { - - const getShardName = (indexNode, record) => { - const shardNameFunc = compilerUtil.compileCode(indexNode.getShardName); - try { - return shardNameFunc({ record }); - } catch(e) { - const errorDetails = `shardCode: ${indexNode.getShardName} :: record: ${JSON.stringify(record)} :: `; - e.message = "Error running index shardname func: " + errorDetails + e.message; - throw e; - } - }; - - const shardName = isNonEmptyString(indexNode.getShardName) - ? `${getShardName(indexNode, record)}.csv` - : 'index.csv'; - - return joinKey(indexDir, shardName); - }; - - const getShardKeysInRange = async (app, indexNode, indexDir, startRecord = null, endRecord = null) => { - const startShardName = !startRecord - ? null - : shardNameFromKey( - getIndexedDataKey( - indexNode, - indexDir, - startRecord, - ), - ); - - const endShardName = !endRecord - ? null - : shardNameFromKey( - getIndexedDataKey( - indexNode, - indexDir, - endRecord, - ), - ); - - return $(await getShardMap(app.datastore, indexDir), [ - fp.filter(k => (startRecord === null || k >= startShardName) - && (endRecord === null || k <= endShardName)), - fp.map(k => joinKey(indexDir, `${k}.csv`)), - ]); - }; - - const ensureShardNameIsInShardMap = async (store, indexDir, indexedDataKey) => { - const map = await getShardMap(store, indexDir); - const shardName = shardNameFromKey(indexedDataKey); - if (!fp.includes(shardName)(map)) { - map.push(shardName); - await writeShardMap(store, indexDir, map); - } - }; - - const getShardMap = async (datastore, indexDir) => { - const shardMapKey = getShardMapKey(indexDir); - try { - return await datastore.loadJson(shardMapKey); - } catch (_) { - await datastore.createJson(shardMapKey, []); - return []; - } - }; - - const writeShardMap = async (datastore, indexDir, shardMap) => await datastore.updateJson( - getShardMapKey(indexDir), - shardMap, - ); - - const getShardMapKey = indexDir => joinKey(indexDir, 'shardMap.json'); - - const getUnshardedIndexDataKey = indexDir => joinKey(indexDir, 'index.csv'); - - const createIndexFile = async (datastore, indexedDataKey, index) => { - if (isShardedIndex(index)) { - const indexDir = getParentKey(indexedDataKey); - const shardMap = await getShardMap(datastore, indexDir); - shardMap.push( - shardNameFromKey(indexedDataKey), - ); - await writeShardMap(datastore, indexDir, shardMap); - } - await datastore.createFile(indexedDataKey, ''); - }; - - const shardNameFromKey = key => $(key, [ - splitKey, - fp.last, - ]).replace('.csv', ''); - - const getIndexKey_BasedOnDecendant = (decendantKey, indexNode) => { - if (isGlobalIndex(indexNode)) { return `${indexNode.nodeKey()}`; } - - const indexedDataParentKey = getActualKeyOfParent( - indexNode.parent().nodeKey(), - decendantKey, - ); - - return joinKey( - indexedDataParentKey, - indexNode.name, - ); - }; - - const generateSchema = (hierarchy, indexNode) => { - const recordNodes = getAllowedRecordNodesForIndex(hierarchy, indexNode); - const mappedRecords = $(recordNodes, [ - fp.map(n => mapRecord(createSampleRecord(n), indexNode)), - ]); - - // always has record key and sort key - const schema = { - sortKey: all$1.string, - key: all$1.string, - }; - - const fieldsHas = fp.has(schema); - const setField = (fieldName, value) => { - if (value === null || value === undefined) { return; } - - const thisType = detectType(value); - if (fieldsHas(fieldName)) { - if (schema[fieldName] !== thisType) { - schema[fieldName] = all$1.string; - } - } else { - schema[fieldName] = thisType; - } - }; - - for (const mappedRec of mappedRecords) { - for (const f in mappedRec) { - setField(f, mappedRec[f]); - } - } - - // returing an array of {name, type} - return $(schema, [ - fp.keys, - fp.map(k => ({ name: k, type: schema[k].name })), - fp.filter(s => s.name !== 'sortKey'), - fp.orderBy('name', ['desc']), // reverse aplha - fp.concat([{ name: 'sortKey', type: all$1.string.name }]), // sortKey on end - fp.reverse, // sortKey first, then rest are alphabetical - ]); - }; - - const createSampleRecord = recordNode => constructRecord( - recordNode, - getSampleFieldValue, - recordNode.parent().nodeKey(), - ); - - var global$1 = (typeof global !== "undefined" ? global : - typeof self !== "undefined" ? self : - typeof window !== "undefined" ? window : {}); - - var lookup = []; - var revLookup = []; - var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array; - var inited = false; - function init () { - inited = true; - var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; - for (var i = 0, len = code.length; i < len; ++i) { - lookup[i] = code[i]; - revLookup[code.charCodeAt(i)] = i; - } - - revLookup['-'.charCodeAt(0)] = 62; - revLookup['_'.charCodeAt(0)] = 63; - } - - function toByteArray (b64) { - if (!inited) { - init(); - } - var i, j, l, tmp, placeHolders, arr; - var len = b64.length; - - if (len % 4 > 0) { - throw new Error('Invalid string. Length must be a multiple of 4') - } - - // the number of equal signs (place holders) - // if there are two placeholders, than the two characters before it - // represent one byte - // if there is only one, then the three characters before it represent 2 bytes - // this is just a cheap hack to not do indexOf twice - placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0; - - // base64 is 4/3 + up to two characters of the original data - arr = new Arr(len * 3 / 4 - placeHolders); - - // if there are placeholders, only get up to the last complete 4 chars - l = placeHolders > 0 ? len - 4 : len; - - var L = 0; - - for (i = 0, j = 0; i < l; i += 4, j += 3) { - tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]; - arr[L++] = (tmp >> 16) & 0xFF; - arr[L++] = (tmp >> 8) & 0xFF; - arr[L++] = tmp & 0xFF; - } - - if (placeHolders === 2) { - tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4); - arr[L++] = tmp & 0xFF; - } else if (placeHolders === 1) { - tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2); - arr[L++] = (tmp >> 8) & 0xFF; - arr[L++] = tmp & 0xFF; - } - - return arr - } - - function tripletToBase64 (num) { - return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F] - } - - function encodeChunk (uint8, start, end) { - var tmp; - var output = []; - for (var i = start; i < end; i += 3) { - tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2]); - output.push(tripletToBase64(tmp)); - } - return output.join('') - } - - function fromByteArray (uint8) { - if (!inited) { - init(); - } - var tmp; - var len = uint8.length; - var extraBytes = len % 3; // if we have 1 byte left, pad 2 bytes - var output = ''; - var parts = []; - var maxChunkLength = 16383; // must be multiple of 3 - - // go through the array every three bytes, we'll deal with trailing stuff later - for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) { - parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength))); - } - - // pad the end with zeros, but make sure to not forget the extra bytes - if (extraBytes === 1) { - tmp = uint8[len - 1]; - output += lookup[tmp >> 2]; - output += lookup[(tmp << 4) & 0x3F]; - output += '=='; - } else if (extraBytes === 2) { - tmp = (uint8[len - 2] << 8) + (uint8[len - 1]); - output += lookup[tmp >> 10]; - output += lookup[(tmp >> 4) & 0x3F]; - output += lookup[(tmp << 2) & 0x3F]; - output += '='; - } - - parts.push(output); - - return parts.join('') - } - - function read (buffer, offset, isLE, mLen, nBytes) { - var e, m; - var eLen = nBytes * 8 - mLen - 1; - var eMax = (1 << eLen) - 1; - var eBias = eMax >> 1; - var nBits = -7; - var i = isLE ? (nBytes - 1) : 0; - var d = isLE ? -1 : 1; - var s = buffer[offset + i]; - - i += d; - - e = s & ((1 << (-nBits)) - 1); - s >>= (-nBits); - nBits += eLen; - for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {} - - m = e & ((1 << (-nBits)) - 1); - e >>= (-nBits); - nBits += mLen; - for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {} - - if (e === 0) { - e = 1 - eBias; - } else if (e === eMax) { - return m ? NaN : ((s ? -1 : 1) * Infinity) - } else { - m = m + Math.pow(2, mLen); - e = e - eBias; - } - return (s ? -1 : 1) * m * Math.pow(2, e - mLen) - } - - function write (buffer, value, offset, isLE, mLen, nBytes) { - var e, m, c; - var eLen = nBytes * 8 - mLen - 1; - var eMax = (1 << eLen) - 1; - var eBias = eMax >> 1; - var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0); - var i = isLE ? 0 : (nBytes - 1); - var d = isLE ? 1 : -1; - var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0; - - value = Math.abs(value); - - if (isNaN(value) || value === Infinity) { - m = isNaN(value) ? 1 : 0; - e = eMax; - } else { - e = Math.floor(Math.log(value) / Math.LN2); - if (value * (c = Math.pow(2, -e)) < 1) { - e--; - c *= 2; - } - if (e + eBias >= 1) { - value += rt / c; - } else { - value += rt * Math.pow(2, 1 - eBias); - } - if (value * c >= 2) { - e++; - c /= 2; - } - - if (e + eBias >= eMax) { - m = 0; - e = eMax; - } else if (e + eBias >= 1) { - m = (value * c - 1) * Math.pow(2, mLen); - e = e + eBias; - } else { - m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen); - e = 0; - } - } - - for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} - - e = (e << mLen) | m; - eLen += mLen; - for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} - - buffer[offset + i - d] |= s * 128; - } - - var toString = {}.toString; - - var isArray = Array.isArray || function (arr) { - return toString.call(arr) == '[object Array]'; - }; - - var INSPECT_MAX_BYTES = 50; - - /** - * If `Buffer.TYPED_ARRAY_SUPPORT`: - * === true Use Uint8Array implementation (fastest) - * === false Use Object implementation (most compatible, even IE6) - * - * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, - * Opera 11.6+, iOS 4.2+. - * - * Due to various browser bugs, sometimes the Object implementation will be used even - * when the browser supports typed arrays. - * - * Note: - * - * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances, - * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438. - * - * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function. - * - * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of - * incorrect length in some situations. - - * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they - * get the Object implementation, which is slower but behaves correctly. - */ - Buffer.TYPED_ARRAY_SUPPORT = global$1.TYPED_ARRAY_SUPPORT !== undefined - ? global$1.TYPED_ARRAY_SUPPORT - : true; - - function kMaxLength () { - return Buffer.TYPED_ARRAY_SUPPORT - ? 0x7fffffff - : 0x3fffffff - } - - function createBuffer (that, length) { - if (kMaxLength() < length) { - throw new RangeError('Invalid typed array length') - } - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - that = new Uint8Array(length); - that.__proto__ = Buffer.prototype; - } else { - // Fallback: Return an object instance of the Buffer class - if (that === null) { - that = new Buffer(length); - } - that.length = length; - } - - return that - } - - /** - * The Buffer constructor returns instances of `Uint8Array` that have their - * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of - * `Uint8Array`, so the returned instances will have all the node `Buffer` methods - * and the `Uint8Array` methods. Square bracket notation works as expected -- it - * returns a single octet. - * - * The `Uint8Array` prototype remains unmodified. - */ - - function Buffer (arg, encodingOrOffset, length) { - if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) { - return new Buffer(arg, encodingOrOffset, length) - } - - // Common case. - if (typeof arg === 'number') { - if (typeof encodingOrOffset === 'string') { - throw new Error( - 'If encoding is specified then the first argument must be a string' - ) - } - return allocUnsafe(this, arg) - } - return from(this, arg, encodingOrOffset, length) - } - - Buffer.poolSize = 8192; // not used by this implementation - - // TODO: Legacy, not needed anymore. Remove in next major version. - Buffer._augment = function (arr) { - arr.__proto__ = Buffer.prototype; - return arr - }; - - function from (that, value, encodingOrOffset, length) { - if (typeof value === 'number') { - throw new TypeError('"value" argument must not be a number') - } - - if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) { - return fromArrayBuffer(that, value, encodingOrOffset, length) - } - - if (typeof value === 'string') { - return fromString(that, value, encodingOrOffset) - } - - return fromObject(that, value) - } - - /** - * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError - * if value is a number. - * Buffer.from(str[, encoding]) - * Buffer.from(array) - * Buffer.from(buffer) - * Buffer.from(arrayBuffer[, byteOffset[, length]]) - **/ - Buffer.from = function (value, encodingOrOffset, length) { - return from(null, value, encodingOrOffset, length) - }; - - if (Buffer.TYPED_ARRAY_SUPPORT) { - Buffer.prototype.__proto__ = Uint8Array.prototype; - Buffer.__proto__ = Uint8Array; - } - - function assertSize (size) { - if (typeof size !== 'number') { - throw new TypeError('"size" argument must be a number') - } else if (size < 0) { - throw new RangeError('"size" argument must not be negative') - } - } - - function alloc (that, size, fill, encoding) { - assertSize(size); - if (size <= 0) { - return createBuffer(that, size) - } - if (fill !== undefined) { - // Only pay attention to encoding if it's a string. This - // prevents accidentally sending in a number that would - // be interpretted as a start offset. - return typeof encoding === 'string' - ? createBuffer(that, size).fill(fill, encoding) - : createBuffer(that, size).fill(fill) - } - return createBuffer(that, size) - } - - /** - * Creates a new filled Buffer instance. - * alloc(size[, fill[, encoding]]) - **/ - Buffer.alloc = function (size, fill, encoding) { - return alloc(null, size, fill, encoding) - }; - - function allocUnsafe (that, size) { - assertSize(size); - that = createBuffer(that, size < 0 ? 0 : checked(size) | 0); - if (!Buffer.TYPED_ARRAY_SUPPORT) { - for (var i = 0; i < size; ++i) { - that[i] = 0; - } - } - return that - } - - /** - * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance. - * */ - Buffer.allocUnsafe = function (size) { - return allocUnsafe(null, size) - }; - /** - * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance. - */ - Buffer.allocUnsafeSlow = function (size) { - return allocUnsafe(null, size) - }; - - function fromString (that, string, encoding) { - if (typeof encoding !== 'string' || encoding === '') { - encoding = 'utf8'; - } - - if (!Buffer.isEncoding(encoding)) { - throw new TypeError('"encoding" must be a valid string encoding') - } - - var length = byteLength(string, encoding) | 0; - that = createBuffer(that, length); - - var actual = that.write(string, encoding); - - if (actual !== length) { - // Writing a hex string, for example, that contains invalid characters will - // cause everything after the first invalid character to be ignored. (e.g. - // 'abxxcd' will be treated as 'ab') - that = that.slice(0, actual); - } - - return that - } - - function fromArrayLike (that, array) { - var length = array.length < 0 ? 0 : checked(array.length) | 0; - that = createBuffer(that, length); - for (var i = 0; i < length; i += 1) { - that[i] = array[i] & 255; - } - return that - } - - function fromArrayBuffer (that, array, byteOffset, length) { - array.byteLength; // this throws if `array` is not a valid ArrayBuffer - - if (byteOffset < 0 || array.byteLength < byteOffset) { - throw new RangeError('\'offset\' is out of bounds') - } - - if (array.byteLength < byteOffset + (length || 0)) { - throw new RangeError('\'length\' is out of bounds') - } - - if (byteOffset === undefined && length === undefined) { - array = new Uint8Array(array); - } else if (length === undefined) { - array = new Uint8Array(array, byteOffset); - } else { - array = new Uint8Array(array, byteOffset, length); - } - - if (Buffer.TYPED_ARRAY_SUPPORT) { - // Return an augmented `Uint8Array` instance, for best performance - that = array; - that.__proto__ = Buffer.prototype; - } else { - // Fallback: Return an object instance of the Buffer class - that = fromArrayLike(that, array); - } - return that - } - - function fromObject (that, obj) { - if (internalIsBuffer(obj)) { - var len = checked(obj.length) | 0; - that = createBuffer(that, len); - - if (that.length === 0) { - return that - } - - obj.copy(that, 0, 0, len); - return that - } - - if (obj) { - if ((typeof ArrayBuffer !== 'undefined' && - obj.buffer instanceof ArrayBuffer) || 'length' in obj) { - if (typeof obj.length !== 'number' || isnan(obj.length)) { - return createBuffer(that, 0) - } - return fromArrayLike(that, obj) - } - - if (obj.type === 'Buffer' && isArray(obj.data)) { - return fromArrayLike(that, obj.data) - } - } - - throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.') - } - - function checked (length) { - // Note: cannot use `length < kMaxLength()` here because that fails when - // length is NaN (which is otherwise coerced to zero.) - if (length >= kMaxLength()) { - throw new RangeError('Attempt to allocate Buffer larger than maximum ' + - 'size: 0x' + kMaxLength().toString(16) + ' bytes') - } - return length | 0 - } - Buffer.isBuffer = isBuffer; - function internalIsBuffer (b) { - return !!(b != null && b._isBuffer) - } - - Buffer.compare = function compare (a, b) { - if (!internalIsBuffer(a) || !internalIsBuffer(b)) { - throw new TypeError('Arguments must be Buffers') - } - - if (a === b) return 0 - - var x = a.length; - var y = b.length; - - for (var i = 0, len = Math.min(x, y); i < len; ++i) { - if (a[i] !== b[i]) { - x = a[i]; - y = b[i]; - break - } - } - - if (x < y) return -1 - if (y < x) return 1 - return 0 - }; - - Buffer.isEncoding = function isEncoding (encoding) { - switch (String(encoding).toLowerCase()) { - case 'hex': - case 'utf8': - case 'utf-8': - case 'ascii': - case 'latin1': - case 'binary': - case 'base64': - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return true - default: - return false - } - }; - - Buffer.concat = function concat (list, length) { - if (!isArray(list)) { - throw new TypeError('"list" argument must be an Array of Buffers') - } - - if (list.length === 0) { - return Buffer.alloc(0) - } - - var i; - if (length === undefined) { - length = 0; - for (i = 0; i < list.length; ++i) { - length += list[i].length; - } - } - - var buffer = Buffer.allocUnsafe(length); - var pos = 0; - for (i = 0; i < list.length; ++i) { - var buf = list[i]; - if (!internalIsBuffer(buf)) { - throw new TypeError('"list" argument must be an Array of Buffers') - } - buf.copy(buffer, pos); - pos += buf.length; - } - return buffer - }; - - function byteLength (string, encoding) { - if (internalIsBuffer(string)) { - return string.length - } - if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' && - (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) { - return string.byteLength - } - if (typeof string !== 'string') { - string = '' + string; - } - - var len = string.length; - if (len === 0) return 0 - - // Use a for loop to avoid recursion - var loweredCase = false; - for (;;) { - switch (encoding) { - case 'ascii': - case 'latin1': - case 'binary': - return len - case 'utf8': - case 'utf-8': - case undefined: - return utf8ToBytes(string).length - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return len * 2 - case 'hex': - return len >>> 1 - case 'base64': - return base64ToBytes(string).length - default: - if (loweredCase) return utf8ToBytes(string).length // assume utf8 - encoding = ('' + encoding).toLowerCase(); - loweredCase = true; - } - } - } - Buffer.byteLength = byteLength; - - function slowToString (encoding, start, end) { - var loweredCase = false; - - // No need to verify that "this.length <= MAX_UINT32" since it's a read-only - // property of a typed array. - - // This behaves neither like String nor Uint8Array in that we set start/end - // to their upper/lower bounds if the value passed is out of range. - // undefined is handled specially as per ECMA-262 6th Edition, - // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization. - if (start === undefined || start < 0) { - start = 0; - } - // Return early if start > this.length. Done here to prevent potential uint32 - // coercion fail below. - if (start > this.length) { - return '' - } - - if (end === undefined || end > this.length) { - end = this.length; - } - - if (end <= 0) { - return '' - } - - // Force coersion to uint32. This will also coerce falsey/NaN values to 0. - end >>>= 0; - start >>>= 0; - - if (end <= start) { - return '' - } - - if (!encoding) encoding = 'utf8'; - - while (true) { - switch (encoding) { - case 'hex': - return hexSlice(this, start, end) - - case 'utf8': - case 'utf-8': - return utf8Slice(this, start, end) - - case 'ascii': - return asciiSlice(this, start, end) - - case 'latin1': - case 'binary': - return latin1Slice(this, start, end) - - case 'base64': - return base64Slice(this, start, end) - - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return utf16leSlice(this, start, end) - - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = (encoding + '').toLowerCase(); - loweredCase = true; - } - } - } - - // The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect - // Buffer instances. - Buffer.prototype._isBuffer = true; - - function swap (b, n, m) { - var i = b[n]; - b[n] = b[m]; - b[m] = i; - } - - Buffer.prototype.swap16 = function swap16 () { - var len = this.length; - if (len % 2 !== 0) { - throw new RangeError('Buffer size must be a multiple of 16-bits') - } - for (var i = 0; i < len; i += 2) { - swap(this, i, i + 1); - } - return this - }; - - Buffer.prototype.swap32 = function swap32 () { - var len = this.length; - if (len % 4 !== 0) { - throw new RangeError('Buffer size must be a multiple of 32-bits') - } - for (var i = 0; i < len; i += 4) { - swap(this, i, i + 3); - swap(this, i + 1, i + 2); - } - return this - }; - - Buffer.prototype.swap64 = function swap64 () { - var len = this.length; - if (len % 8 !== 0) { - throw new RangeError('Buffer size must be a multiple of 64-bits') - } - for (var i = 0; i < len; i += 8) { - swap(this, i, i + 7); - swap(this, i + 1, i + 6); - swap(this, i + 2, i + 5); - swap(this, i + 3, i + 4); - } - return this - }; - - Buffer.prototype.toString = function toString () { - var length = this.length | 0; - if (length === 0) return '' - if (arguments.length === 0) return utf8Slice(this, 0, length) - return slowToString.apply(this, arguments) - }; - - Buffer.prototype.equals = function equals (b) { - if (!internalIsBuffer(b)) throw new TypeError('Argument must be a Buffer') - if (this === b) return true - return Buffer.compare(this, b) === 0 - }; - - Buffer.prototype.inspect = function inspect () { - var str = ''; - var max = INSPECT_MAX_BYTES; - if (this.length > 0) { - str = this.toString('hex', 0, max).match(/.{2}/g).join(' '); - if (this.length > max) str += ' ... '; - } - return '' - }; - - Buffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) { - if (!internalIsBuffer(target)) { - throw new TypeError('Argument must be a Buffer') - } - - if (start === undefined) { - start = 0; - } - if (end === undefined) { - end = target ? target.length : 0; - } - if (thisStart === undefined) { - thisStart = 0; - } - if (thisEnd === undefined) { - thisEnd = this.length; - } - - if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) { - throw new RangeError('out of range index') - } - - if (thisStart >= thisEnd && start >= end) { - return 0 - } - if (thisStart >= thisEnd) { - return -1 - } - if (start >= end) { - return 1 - } - - start >>>= 0; - end >>>= 0; - thisStart >>>= 0; - thisEnd >>>= 0; - - if (this === target) return 0 - - var x = thisEnd - thisStart; - var y = end - start; - var len = Math.min(x, y); - - var thisCopy = this.slice(thisStart, thisEnd); - var targetCopy = target.slice(start, end); - - for (var i = 0; i < len; ++i) { - if (thisCopy[i] !== targetCopy[i]) { - x = thisCopy[i]; - y = targetCopy[i]; - break - } - } - - if (x < y) return -1 - if (y < x) return 1 - return 0 - }; - - // Finds either the first index of `val` in `buffer` at offset >= `byteOffset`, - // OR the last index of `val` in `buffer` at offset <= `byteOffset`. - // - // Arguments: - // - buffer - a Buffer to search - // - val - a string, Buffer, or number - // - byteOffset - an index into `buffer`; will be clamped to an int32 - // - encoding - an optional encoding, relevant is val is a string - // - dir - true for indexOf, false for lastIndexOf - function bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) { - // Empty buffer means no match - if (buffer.length === 0) return -1 - - // Normalize byteOffset - if (typeof byteOffset === 'string') { - encoding = byteOffset; - byteOffset = 0; - } else if (byteOffset > 0x7fffffff) { - byteOffset = 0x7fffffff; - } else if (byteOffset < -0x80000000) { - byteOffset = -0x80000000; - } - byteOffset = +byteOffset; // Coerce to Number. - if (isNaN(byteOffset)) { - // byteOffset: it it's undefined, null, NaN, "foo", etc, search whole buffer - byteOffset = dir ? 0 : (buffer.length - 1); - } - - // Normalize byteOffset: negative offsets start from the end of the buffer - if (byteOffset < 0) byteOffset = buffer.length + byteOffset; - if (byteOffset >= buffer.length) { - if (dir) return -1 - else byteOffset = buffer.length - 1; - } else if (byteOffset < 0) { - if (dir) byteOffset = 0; - else return -1 - } - - // Normalize val - if (typeof val === 'string') { - val = Buffer.from(val, encoding); - } - - // Finally, search either indexOf (if dir is true) or lastIndexOf - if (internalIsBuffer(val)) { - // Special case: looking for empty string/buffer always fails - if (val.length === 0) { - return -1 - } - return arrayIndexOf(buffer, val, byteOffset, encoding, dir) - } else if (typeof val === 'number') { - val = val & 0xFF; // Search for a byte value [0-255] - if (Buffer.TYPED_ARRAY_SUPPORT && - typeof Uint8Array.prototype.indexOf === 'function') { - if (dir) { - return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset) - } else { - return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset) - } - } - return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir) - } - - throw new TypeError('val must be string, number or Buffer') - } - - function arrayIndexOf (arr, val, byteOffset, encoding, dir) { - var indexSize = 1; - var arrLength = arr.length; - var valLength = val.length; - - if (encoding !== undefined) { - encoding = String(encoding).toLowerCase(); - if (encoding === 'ucs2' || encoding === 'ucs-2' || - encoding === 'utf16le' || encoding === 'utf-16le') { - if (arr.length < 2 || val.length < 2) { - return -1 - } - indexSize = 2; - arrLength /= 2; - valLength /= 2; - byteOffset /= 2; - } - } - - function read (buf, i) { - if (indexSize === 1) { - return buf[i] - } else { - return buf.readUInt16BE(i * indexSize) - } - } - - var i; - if (dir) { - var foundIndex = -1; - for (i = byteOffset; i < arrLength; i++) { - if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) { - if (foundIndex === -1) foundIndex = i; - if (i - foundIndex + 1 === valLength) return foundIndex * indexSize - } else { - if (foundIndex !== -1) i -= i - foundIndex; - foundIndex = -1; - } - } - } else { - if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength; - for (i = byteOffset; i >= 0; i--) { - var found = true; - for (var j = 0; j < valLength; j++) { - if (read(arr, i + j) !== read(val, j)) { - found = false; - break - } - } - if (found) return i - } - } - - return -1 - } - - Buffer.prototype.includes = function includes (val, byteOffset, encoding) { - return this.indexOf(val, byteOffset, encoding) !== -1 - }; - - Buffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) { - return bidirectionalIndexOf(this, val, byteOffset, encoding, true) - }; - - Buffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) { - return bidirectionalIndexOf(this, val, byteOffset, encoding, false) - }; - - function hexWrite (buf, string, offset, length) { - offset = Number(offset) || 0; - var remaining = buf.length - offset; - if (!length) { - length = remaining; - } else { - length = Number(length); - if (length > remaining) { - length = remaining; - } - } - - // must be an even number of digits - var strLen = string.length; - if (strLen % 2 !== 0) throw new TypeError('Invalid hex string') - - if (length > strLen / 2) { - length = strLen / 2; - } - for (var i = 0; i < length; ++i) { - var parsed = parseInt(string.substr(i * 2, 2), 16); - if (isNaN(parsed)) return i - buf[offset + i] = parsed; - } - return i - } - - function utf8Write (buf, string, offset, length) { - return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) - } - - function asciiWrite (buf, string, offset, length) { - return blitBuffer(asciiToBytes(string), buf, offset, length) - } - - function latin1Write (buf, string, offset, length) { - return asciiWrite(buf, string, offset, length) - } - - function base64Write (buf, string, offset, length) { - return blitBuffer(base64ToBytes(string), buf, offset, length) - } - - function ucs2Write (buf, string, offset, length) { - return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) - } - - Buffer.prototype.write = function write (string, offset, length, encoding) { - // Buffer#write(string) - if (offset === undefined) { - encoding = 'utf8'; - length = this.length; - offset = 0; - // Buffer#write(string, encoding) - } else if (length === undefined && typeof offset === 'string') { - encoding = offset; - length = this.length; - offset = 0; - // Buffer#write(string, offset[, length][, encoding]) - } else if (isFinite(offset)) { - offset = offset | 0; - if (isFinite(length)) { - length = length | 0; - if (encoding === undefined) encoding = 'utf8'; - } else { - encoding = length; - length = undefined; - } - // legacy write(string, encoding, offset, length) - remove in v0.13 - } else { - throw new Error( - 'Buffer.write(string, encoding, offset[, length]) is no longer supported' - ) - } - - var remaining = this.length - offset; - if (length === undefined || length > remaining) length = remaining; - - if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { - throw new RangeError('Attempt to write outside buffer bounds') - } - - if (!encoding) encoding = 'utf8'; - - var loweredCase = false; - for (;;) { - switch (encoding) { - case 'hex': - return hexWrite(this, string, offset, length) - - case 'utf8': - case 'utf-8': - return utf8Write(this, string, offset, length) - - case 'ascii': - return asciiWrite(this, string, offset, length) - - case 'latin1': - case 'binary': - return latin1Write(this, string, offset, length) - - case 'base64': - // Warning: maxLength not taken into account in base64Write - return base64Write(this, string, offset, length) - - case 'ucs2': - case 'ucs-2': - case 'utf16le': - case 'utf-16le': - return ucs2Write(this, string, offset, length) - - default: - if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) - encoding = ('' + encoding).toLowerCase(); - loweredCase = true; - } - } - }; - - Buffer.prototype.toJSON = function toJSON () { - return { - type: 'Buffer', - data: Array.prototype.slice.call(this._arr || this, 0) - } - }; - - function base64Slice (buf, start, end) { - if (start === 0 && end === buf.length) { - return fromByteArray(buf) - } else { - return fromByteArray(buf.slice(start, end)) - } - } - - function utf8Slice (buf, start, end) { - end = Math.min(buf.length, end); - var res = []; - - var i = start; - while (i < end) { - var firstByte = buf[i]; - var codePoint = null; - var bytesPerSequence = (firstByte > 0xEF) ? 4 - : (firstByte > 0xDF) ? 3 - : (firstByte > 0xBF) ? 2 - : 1; - - if (i + bytesPerSequence <= end) { - var secondByte, thirdByte, fourthByte, tempCodePoint; - - switch (bytesPerSequence) { - case 1: - if (firstByte < 0x80) { - codePoint = firstByte; - } - break - case 2: - secondByte = buf[i + 1]; - if ((secondByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F); - if (tempCodePoint > 0x7F) { - codePoint = tempCodePoint; - } - } - break - case 3: - secondByte = buf[i + 1]; - thirdByte = buf[i + 2]; - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F); - if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { - codePoint = tempCodePoint; - } - } - break - case 4: - secondByte = buf[i + 1]; - thirdByte = buf[i + 2]; - fourthByte = buf[i + 3]; - if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { - tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F); - if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { - codePoint = tempCodePoint; - } - } - } - } - - if (codePoint === null) { - // we did not generate a valid codePoint so insert a - // replacement char (U+FFFD) and advance only 1 byte - codePoint = 0xFFFD; - bytesPerSequence = 1; - } else if (codePoint > 0xFFFF) { - // encode to utf16 (surrogate pair dance) - codePoint -= 0x10000; - res.push(codePoint >>> 10 & 0x3FF | 0xD800); - codePoint = 0xDC00 | codePoint & 0x3FF; - } - - res.push(codePoint); - i += bytesPerSequence; - } - - return decodeCodePointsArray(res) - } - - // Based on http://stackoverflow.com/a/22747272/680742, the browser with - // the lowest limit is Chrome, with 0x10000 args. - // We go 1 magnitude less, for safety - var MAX_ARGUMENTS_LENGTH = 0x1000; - - function decodeCodePointsArray (codePoints) { - var len = codePoints.length; - if (len <= MAX_ARGUMENTS_LENGTH) { - return String.fromCharCode.apply(String, codePoints) // avoid extra slice() - } - - // Decode in chunks to avoid "call stack size exceeded". - var res = ''; - var i = 0; - while (i < len) { - res += String.fromCharCode.apply( - String, - codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) - ); - } - return res - } - - function asciiSlice (buf, start, end) { - var ret = ''; - end = Math.min(buf.length, end); - - for (var i = start; i < end; ++i) { - ret += String.fromCharCode(buf[i] & 0x7F); - } - return ret - } - - function latin1Slice (buf, start, end) { - var ret = ''; - end = Math.min(buf.length, end); - - for (var i = start; i < end; ++i) { - ret += String.fromCharCode(buf[i]); - } - return ret - } - - function hexSlice (buf, start, end) { - var len = buf.length; - - if (!start || start < 0) start = 0; - if (!end || end < 0 || end > len) end = len; - - var out = ''; - for (var i = start; i < end; ++i) { - out += toHex(buf[i]); - } - return out - } - - function utf16leSlice (buf, start, end) { - var bytes = buf.slice(start, end); - var res = ''; - for (var i = 0; i < bytes.length; i += 2) { - res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256); - } - return res - } - - Buffer.prototype.slice = function slice (start, end) { - var len = this.length; - start = ~~start; - end = end === undefined ? len : ~~end; - - if (start < 0) { - start += len; - if (start < 0) start = 0; - } else if (start > len) { - start = len; - } - - if (end < 0) { - end += len; - if (end < 0) end = 0; - } else if (end > len) { - end = len; - } - - if (end < start) end = start; - - var newBuf; - if (Buffer.TYPED_ARRAY_SUPPORT) { - newBuf = this.subarray(start, end); - newBuf.__proto__ = Buffer.prototype; - } else { - var sliceLen = end - start; - newBuf = new Buffer(sliceLen, undefined); - for (var i = 0; i < sliceLen; ++i) { - newBuf[i] = this[i + start]; - } - } - - return newBuf - }; - - /* - * Need to make sure that buffer isn't trying to write out of bounds. - */ - function checkOffset (offset, ext, length) { - if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') - if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') - } - - Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var val = this[offset]; - var mul = 1; - var i = 0; - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul; - } - - return val - }; - - Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - checkOffset(offset, byteLength, this.length); - } - - var val = this[offset + --byteLength]; - var mul = 1; - while (byteLength > 0 && (mul *= 0x100)) { - val += this[offset + --byteLength] * mul; - } - - return val - }; - - Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length); - return this[offset] - }; - - Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - return this[offset] | (this[offset + 1] << 8) - }; - - Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - return (this[offset] << 8) | this[offset + 1] - }; - - Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return ((this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16)) + - (this[offset + 3] * 0x1000000) - }; - - Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset] * 0x1000000) + - ((this[offset + 1] << 16) | - (this[offset + 2] << 8) | - this[offset + 3]) - }; - - Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var val = this[offset]; - var mul = 1; - var i = 0; - while (++i < byteLength && (mul *= 0x100)) { - val += this[offset + i] * mul; - } - mul *= 0x80; - - if (val >= mul) val -= Math.pow(2, 8 * byteLength); - - return val - }; - - Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) checkOffset(offset, byteLength, this.length); - - var i = byteLength; - var mul = 1; - var val = this[offset + --i]; - while (i > 0 && (mul *= 0x100)) { - val += this[offset + --i] * mul; - } - mul *= 0x80; - - if (val >= mul) val -= Math.pow(2, 8 * byteLength); - - return val - }; - - Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { - if (!noAssert) checkOffset(offset, 1, this.length); - if (!(this[offset] & 0x80)) return (this[offset]) - return ((0xff - this[offset] + 1) * -1) - }; - - Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - var val = this[offset] | (this[offset + 1] << 8); - return (val & 0x8000) ? val | 0xFFFF0000 : val - }; - - Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 2, this.length); - var val = this[offset + 1] | (this[offset] << 8); - return (val & 0x8000) ? val | 0xFFFF0000 : val - }; - - Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset]) | - (this[offset + 1] << 8) | - (this[offset + 2] << 16) | - (this[offset + 3] << 24) - }; - - Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - - return (this[offset] << 24) | - (this[offset + 1] << 16) | - (this[offset + 2] << 8) | - (this[offset + 3]) - }; - - Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - return read(this, offset, true, 23, 4) - }; - - Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 4, this.length); - return read(this, offset, false, 23, 4) - }; - - Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length); - return read(this, offset, true, 52, 8) - }; - - Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { - if (!noAssert) checkOffset(offset, 8, this.length); - return read(this, offset, false, 52, 8) - }; - - function checkInt (buf, value, offset, ext, max, min) { - if (!internalIsBuffer(buf)) throw new TypeError('"buffer" argument must be a Buffer instance') - if (value > max || value < min) throw new RangeError('"value" argument is out of bounds') - if (offset + ext > buf.length) throw new RangeError('Index out of range') - } - - Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - var maxBytes = Math.pow(2, 8 * byteLength) - 1; - checkInt(this, value, offset, byteLength, maxBytes, 0); - } - - var mul = 1; - var i = 0; - this[offset] = value & 0xFF; - while (++i < byteLength && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF; - } - - return offset + byteLength - }; - - Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - byteLength = byteLength | 0; - if (!noAssert) { - var maxBytes = Math.pow(2, 8 * byteLength) - 1; - checkInt(this, value, offset, byteLength, maxBytes, 0); - } - - var i = byteLength - 1; - var mul = 1; - this[offset + i] = value & 0xFF; - while (--i >= 0 && (mul *= 0x100)) { - this[offset + i] = (value / mul) & 0xFF; - } - - return offset + byteLength - }; - - Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0); - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value); - this[offset] = (value & 0xff); - return offset + 1 - }; - - function objectWriteUInt16 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffff + value + 1; - for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) { - buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>> - (littleEndian ? i : 1 - i) * 8; - } - } - - Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - } else { - objectWriteUInt16(this, value, offset, true); - } - return offset + 2 - }; - - Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8); - this[offset + 1] = (value & 0xff); - } else { - objectWriteUInt16(this, value, offset, false); - } - return offset + 2 - }; - - function objectWriteUInt32 (buf, value, offset, littleEndian) { - if (value < 0) value = 0xffffffff + value + 1; - for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) { - buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff; - } - } - - Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset + 3] = (value >>> 24); - this[offset + 2] = (value >>> 16); - this[offset + 1] = (value >>> 8); - this[offset] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, true); - } - return offset + 4 - }; - - Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24); - this[offset + 1] = (value >>> 16); - this[offset + 2] = (value >>> 8); - this[offset + 3] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, false); - } - return offset + 4 - }; - - Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1); - - checkInt(this, value, offset, byteLength, limit - 1, -limit); - } - - var i = 0; - var mul = 1; - var sub = 0; - this[offset] = value & 0xFF; - while (++i < byteLength && (mul *= 0x100)) { - if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) { - sub = 1; - } - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF; - } - - return offset + byteLength - }; - - Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) { - var limit = Math.pow(2, 8 * byteLength - 1); - - checkInt(this, value, offset, byteLength, limit - 1, -limit); - } - - var i = byteLength - 1; - var mul = 1; - var sub = 0; - this[offset + i] = value & 0xFF; - while (--i >= 0 && (mul *= 0x100)) { - if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) { - sub = 1; - } - this[offset + i] = ((value / mul) >> 0) - sub & 0xFF; - } - - return offset + byteLength - }; - - Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80); - if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value); - if (value < 0) value = 0xff + value + 1; - this[offset] = (value & 0xff); - return offset + 1 - }; - - Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - } else { - objectWriteUInt16(this, value, offset, true); - } - return offset + 2 - }; - - Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 8); - this[offset + 1] = (value & 0xff); - } else { - objectWriteUInt16(this, value, offset, false); - } - return offset + 2 - }; - - Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000); - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value & 0xff); - this[offset + 1] = (value >>> 8); - this[offset + 2] = (value >>> 16); - this[offset + 3] = (value >>> 24); - } else { - objectWriteUInt32(this, value, offset, true); - } - return offset + 4 - }; - - Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { - value = +value; - offset = offset | 0; - if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000); - if (value < 0) value = 0xffffffff + value + 1; - if (Buffer.TYPED_ARRAY_SUPPORT) { - this[offset] = (value >>> 24); - this[offset + 1] = (value >>> 16); - this[offset + 2] = (value >>> 8); - this[offset + 3] = (value & 0xff); - } else { - objectWriteUInt32(this, value, offset, false); - } - return offset + 4 - }; - - function checkIEEE754 (buf, value, offset, ext, max, min) { - if (offset + ext > buf.length) throw new RangeError('Index out of range') - if (offset < 0) throw new RangeError('Index out of range') - } - - function writeFloat (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 4); - } - write(buf, value, offset, littleEndian, 23, 4); - return offset + 4 - } - - Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { - return writeFloat(this, value, offset, true, noAssert) - }; - - Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { - return writeFloat(this, value, offset, false, noAssert) - }; - - function writeDouble (buf, value, offset, littleEndian, noAssert) { - if (!noAssert) { - checkIEEE754(buf, value, offset, 8); - } - write(buf, value, offset, littleEndian, 52, 8); - return offset + 8 - } - - Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { - return writeDouble(this, value, offset, true, noAssert) - }; - - Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { - return writeDouble(this, value, offset, false, noAssert) - }; - - // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) - Buffer.prototype.copy = function copy (target, targetStart, start, end) { - if (!start) start = 0; - if (!end && end !== 0) end = this.length; - if (targetStart >= target.length) targetStart = target.length; - if (!targetStart) targetStart = 0; - if (end > 0 && end < start) end = start; - - // Copy 0 bytes; we're done - if (end === start) return 0 - if (target.length === 0 || this.length === 0) return 0 - - // Fatal error conditions - if (targetStart < 0) { - throw new RangeError('targetStart out of bounds') - } - if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds') - if (end < 0) throw new RangeError('sourceEnd out of bounds') - - // Are we oob? - if (end > this.length) end = this.length; - if (target.length - targetStart < end - start) { - end = target.length - targetStart + start; - } - - var len = end - start; - var i; - - if (this === target && start < targetStart && targetStart < end) { - // descending copy from end - for (i = len - 1; i >= 0; --i) { - target[i + targetStart] = this[i + start]; - } - } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) { - // ascending copy from start - for (i = 0; i < len; ++i) { - target[i + targetStart] = this[i + start]; - } - } else { - Uint8Array.prototype.set.call( - target, - this.subarray(start, start + len), - targetStart - ); - } - - return len - }; - - // Usage: - // buffer.fill(number[, offset[, end]]) - // buffer.fill(buffer[, offset[, end]]) - // buffer.fill(string[, offset[, end]][, encoding]) - Buffer.prototype.fill = function fill (val, start, end, encoding) { - // Handle string cases: - if (typeof val === 'string') { - if (typeof start === 'string') { - encoding = start; - start = 0; - end = this.length; - } else if (typeof end === 'string') { - encoding = end; - end = this.length; - } - if (val.length === 1) { - var code = val.charCodeAt(0); - if (code < 256) { - val = code; - } - } - if (encoding !== undefined && typeof encoding !== 'string') { - throw new TypeError('encoding must be a string') - } - if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) { - throw new TypeError('Unknown encoding: ' + encoding) - } - } else if (typeof val === 'number') { - val = val & 255; - } - - // Invalid ranges are not set to a default, so can range check early. - if (start < 0 || this.length < start || this.length < end) { - throw new RangeError('Out of range index') - } - - if (end <= start) { - return this - } - - start = start >>> 0; - end = end === undefined ? this.length : end >>> 0; - - if (!val) val = 0; - - var i; - if (typeof val === 'number') { - for (i = start; i < end; ++i) { - this[i] = val; - } - } else { - var bytes = internalIsBuffer(val) - ? val - : utf8ToBytes(new Buffer(val, encoding).toString()); - var len = bytes.length; - for (i = 0; i < end - start; ++i) { - this[i + start] = bytes[i % len]; - } - } - - return this - }; - - // HELPER FUNCTIONS - // ================ - - var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g; - - function base64clean (str) { - // Node strips out invalid characters like \n and \t from the string, base64-js does not - str = stringtrim(str).replace(INVALID_BASE64_RE, ''); - // Node converts strings with length < 2 to '' - if (str.length < 2) return '' - // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not - while (str.length % 4 !== 0) { - str = str + '='; - } - return str - } - - function stringtrim (str) { - if (str.trim) return str.trim() - return str.replace(/^\s+|\s+$/g, '') - } - - function toHex (n) { - if (n < 16) return '0' + n.toString(16) - return n.toString(16) - } - - function utf8ToBytes (string, units) { - units = units || Infinity; - var codePoint; - var length = string.length; - var leadSurrogate = null; - var bytes = []; - - for (var i = 0; i < length; ++i) { - codePoint = string.charCodeAt(i); - - // is surrogate component - if (codePoint > 0xD7FF && codePoint < 0xE000) { - // last char was a lead - if (!leadSurrogate) { - // no lead yet - if (codePoint > 0xDBFF) { - // unexpected trail - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - continue - } else if (i + 1 === length) { - // unpaired lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - continue - } - - // valid lead - leadSurrogate = codePoint; - - continue - } - - // 2 leads in a row - if (codePoint < 0xDC00) { - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - leadSurrogate = codePoint; - continue - } - - // valid surrogate pair - codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000; - } else if (leadSurrogate) { - // valid bmp char, but last char was a lead - if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD); - } - - leadSurrogate = null; - - // encode utf8 - if (codePoint < 0x80) { - if ((units -= 1) < 0) break - bytes.push(codePoint); - } else if (codePoint < 0x800) { - if ((units -= 2) < 0) break - bytes.push( - codePoint >> 0x6 | 0xC0, - codePoint & 0x3F | 0x80 - ); - } else if (codePoint < 0x10000) { - if ((units -= 3) < 0) break - bytes.push( - codePoint >> 0xC | 0xE0, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ); - } else if (codePoint < 0x110000) { - if ((units -= 4) < 0) break - bytes.push( - codePoint >> 0x12 | 0xF0, - codePoint >> 0xC & 0x3F | 0x80, - codePoint >> 0x6 & 0x3F | 0x80, - codePoint & 0x3F | 0x80 - ); - } else { - throw new Error('Invalid code point') - } - } - - return bytes - } - - function asciiToBytes (str) { - var byteArray = []; - for (var i = 0; i < str.length; ++i) { - // Node's code seems to be doing this and not & 0x7F.. - byteArray.push(str.charCodeAt(i) & 0xFF); - } - return byteArray - } - - function utf16leToBytes (str, units) { - var c, hi, lo; - var byteArray = []; - for (var i = 0; i < str.length; ++i) { - if ((units -= 2) < 0) break - - c = str.charCodeAt(i); - hi = c >> 8; - lo = c % 256; - byteArray.push(lo); - byteArray.push(hi); - } - - return byteArray - } - - - function base64ToBytes (str) { - return toByteArray(base64clean(str)) - } - - function blitBuffer (src, dst, offset, length) { - for (var i = 0; i < length; ++i) { - if ((i + offset >= dst.length) || (i >= src.length)) break - dst[i + offset] = src[i]; - } - return i - } - - function isnan (val) { - return val !== val // eslint-disable-line no-self-compare - } - - - // the following is from is-buffer, also by Feross Aboukhadijeh and with same lisence - // The _isBuffer check is for Safari 5-7 support, because it's missing - // Object.prototype.constructor. Remove this eventually - function isBuffer(obj) { - return obj != null && (!!obj._isBuffer || isFastBuffer(obj) || isSlowBuffer(obj)) - } - - function isFastBuffer (obj) { - return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj) - } - - // For Node v0.10 support. Remove this eventually. - function isSlowBuffer (obj) { - return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isFastBuffer(obj.slice(0, 0)) - } - - // Copyright Joyent, Inc. and other Node contributors. - var isBufferEncoding = Buffer.isEncoding - || function(encoding) { - switch (encoding && encoding.toLowerCase()) { - case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true; - default: return false; - } - }; - - - function assertEncoding(encoding) { - if (encoding && !isBufferEncoding(encoding)) { - throw new Error('Unknown encoding: ' + encoding); - } - } - - // StringDecoder provides an interface for efficiently splitting a series of - // buffers into a series of JS strings without breaking apart multi-byte - // characters. CESU-8 is handled as part of the UTF-8 encoding. - // - // @TODO Handling all encodings inside a single object makes it very difficult - // to reason about this code, so it should be split up in the future. - // @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code - // points as used by CESU-8. - function StringDecoder(encoding) { - this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, ''); - assertEncoding(encoding); - switch (this.encoding) { - case 'utf8': - // CESU-8 represents each of Surrogate Pair by 3-bytes - this.surrogateSize = 3; - break; - case 'ucs2': - case 'utf16le': - // UTF-16 represents each of Surrogate Pair by 2-bytes - this.surrogateSize = 2; - this.detectIncompleteChar = utf16DetectIncompleteChar; - break; - case 'base64': - // Base-64 stores 3 bytes in 4 chars, and pads the remainder. - this.surrogateSize = 3; - this.detectIncompleteChar = base64DetectIncompleteChar; - break; - default: - this.write = passThroughWrite; - return; - } - - // Enough space to store all bytes of a single character. UTF-8 needs 4 - // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate). - this.charBuffer = new Buffer(6); - // Number of bytes received for the current incomplete multi-byte character. - this.charReceived = 0; - // Number of bytes expected for the current incomplete multi-byte character. - this.charLength = 0; - } - - // write decodes the given buffer and returns it as JS string that is - // guaranteed to not contain any partial multi-byte characters. Any partial - // character found at the end of the buffer is buffered up, and will be - // returned when calling write again with the remaining bytes. - // - // Note: Converting a Buffer containing an orphan surrogate to a String - // currently works, but converting a String to a Buffer (via `new Buffer`, or - // Buffer#write) will replace incomplete surrogates with the unicode - // replacement character. See https://codereview.chromium.org/121173009/ . - StringDecoder.prototype.write = function(buffer) { - var charStr = ''; - // if our last write ended with an incomplete multibyte character - while (this.charLength) { - // determine how many remaining bytes this buffer has to offer for this char - var available = (buffer.length >= this.charLength - this.charReceived) ? - this.charLength - this.charReceived : - buffer.length; - - // add the new bytes to the char buffer - buffer.copy(this.charBuffer, this.charReceived, 0, available); - this.charReceived += available; - - if (this.charReceived < this.charLength) { - // still not enough chars in this buffer? wait for more ... - return ''; - } - - // remove bytes belonging to the current character from the buffer - buffer = buffer.slice(available, buffer.length); - - // get the character that was split - charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding); - - // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character - var charCode = charStr.charCodeAt(charStr.length - 1); - if (charCode >= 0xD800 && charCode <= 0xDBFF) { - this.charLength += this.surrogateSize; - charStr = ''; - continue; - } - this.charReceived = this.charLength = 0; - - // if there are no more bytes in this buffer, just emit our char - if (buffer.length === 0) { - return charStr; - } - break; - } - - // determine and set charLength / charReceived - this.detectIncompleteChar(buffer); - - var end = buffer.length; - if (this.charLength) { - // buffer the incomplete character bytes we got - buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end); - end -= this.charReceived; - } - - charStr += buffer.toString(this.encoding, 0, end); - - var end = charStr.length - 1; - var charCode = charStr.charCodeAt(end); - // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character - if (charCode >= 0xD800 && charCode <= 0xDBFF) { - var size = this.surrogateSize; - this.charLength += size; - this.charReceived += size; - this.charBuffer.copy(this.charBuffer, size, 0, size); - buffer.copy(this.charBuffer, 0, 0, size); - return charStr.substring(0, end); - } - - // or just emit the charStr - return charStr; - }; - - // detectIncompleteChar determines if there is an incomplete UTF-8 character at - // the end of the given buffer. If so, it sets this.charLength to the byte - // length that character, and sets this.charReceived to the number of bytes - // that are available for this character. - StringDecoder.prototype.detectIncompleteChar = function(buffer) { - // determine how many bytes we have to check at the end of this buffer - var i = (buffer.length >= 3) ? 3 : buffer.length; - - // Figure out if one of the last i bytes of our buffer announces an - // incomplete char. - for (; i > 0; i--) { - var c = buffer[buffer.length - i]; - - // See http://en.wikipedia.org/wiki/UTF-8#Description - - // 110XXXXX - if (i == 1 && c >> 5 == 0x06) { - this.charLength = 2; - break; - } - - // 1110XXXX - if (i <= 2 && c >> 4 == 0x0E) { - this.charLength = 3; - break; - } - - // 11110XXX - if (i <= 3 && c >> 3 == 0x1E) { - this.charLength = 4; - break; - } - } - this.charReceived = i; - }; - - StringDecoder.prototype.end = function(buffer) { - var res = ''; - if (buffer && buffer.length) - res = this.write(buffer); - - if (this.charReceived) { - var cr = this.charReceived; - var buf = this.charBuffer; - var enc = this.encoding; - res += buf.slice(0, cr).toString(enc); - } - - return res; - }; - - function passThroughWrite(buffer) { - return buffer.toString(this.encoding); - } - - function utf16DetectIncompleteChar(buffer) { - this.charReceived = buffer.length % 2; - this.charLength = this.charReceived ? 2 : 0; - } - - function base64DetectIncompleteChar(buffer) { - this.charReceived = buffer.length % 3; - this.charLength = this.charReceived ? 3 : 0; - } - - const BUFFER_MAX_BYTES = 524288; // 0.5Mb - - const CONTINUE_READING_RECORDS = "CONTINUE_READING"; - const READ_REMAINING_TEXT = "READ_REMAINING"; - const CANCEL_READ = "CANCEL"; - - const getIndexWriter = (hierarchy, indexNode, readableStream, writableStream, end) => { - const schema = generateSchema(hierarchy, indexNode); - - return ({ - read: read$1(readableStream, schema), - updateIndex: updateIndex(readableStream, writableStream, schema) - }); - }; - - const getIndexReader = (hierarchy, indexNode, readableStream) => - read$1( - readableStream, - generateSchema(hierarchy, indexNode) - ); - - const updateIndex = (readableStream, writableStream, schema) => async (itemsToWrite, keysToRemove) => { - const write = newOutputWriter(BUFFER_MAX_BYTES, writableStream); - const writtenItems = []; - await read$1(readableStream, schema)( - async indexedItem => { - const updated = fp.find(i => indexedItem.key === i.key)(itemsToWrite); - const removed = fp.find(k => indexedItem.key === k)(keysToRemove); - - if(isSomething(removed)) - return CONTINUE_READING_RECORDS; - - if(isSomething(updated)) { - const serializedItem = serializeItem(schema, updated); - await write(serializedItem); - writtenItems.push(updated); - } else { - await write( - serializeItem(schema, indexedItem) - ); - } - - return CONTINUE_READING_RECORDS; - - }, - async text => await write(text) - ); - - if(writtenItems.length !== itemsToWrite.length) { - const toAdd = fp.difference(itemsToWrite, writtenItems); - for(let added of toAdd) { - await write( - serializeItem(schema, added) - ); - } - } else if(writtenItems.length === 0) { - // potentially are no records - await write(""); - } - - await write(); - await writableStream.end(); - }; - - const read$1 = (readableStream, schema) => async (onGetItem, onGetText) => { - const readInput = newInputReader(readableStream); - let text = await readInput(); - let status = CONTINUE_READING_RECORDS; - while(text.length > 0) { - - if(status === READ_REMAINING_TEXT) { - await onGetText(text); - continue; - } - - if(status === CANCEL_READ) { - return; - } - - let rowText = ""; - let currentCharIndex=0; - for(let currentChar of text) { - rowText += currentChar; - if(currentChar === "\r") { - status = await onGetItem( - deserializeRow(schema, rowText) - ); - rowText = ""; - if(status === READ_REMAINING_TEXT) { - break; - } - } - currentCharIndex++; - } - - if(currentCharIndex < text.length -1) { - await onGetText(text.substring(currentCharIndex + 1)); - } - - text = await readInput(); - } - - await readableStream.destroy(); - - }; - - const newOutputWriter = (flushBoundary, writableStream) => { - - let currentBuffer = null; - - return async (text) => { - - if(fp.isString(text) && currentBuffer === null) - currentBuffer = safeBuffer.Buffer.from(text, "utf8"); - else if(fp.isString(text)) - currentBuffer = safeBuffer.Buffer.concat([ - currentBuffer, - safeBuffer.Buffer.from(text, "utf8") - ]); - - if(currentBuffer !== null && - (currentBuffer.length > flushBoundary - || !fp.isString(text))) { - - await writableStream.write(currentBuffer); - currentBuffer = null; - } - } - }; - - const newInputReader = (readableStream) => { - - const decoder = new StringDecoder('utf8'); - let remainingBytes = []; - - return async () => { - - let nextBytesBuffer = await readableStream.read(BUFFER_MAX_BYTES); - const remainingBuffer = safeBuffer.Buffer.from(remainingBytes); - - if(!nextBytesBuffer) nextBytesBuffer = safeBuffer.Buffer.from([]); - - const moreToRead = nextBytesBuffer.length === BUFFER_MAX_BYTES; - - const buffer = safeBuffer.Buffer.concat( - [remainingBuffer, nextBytesBuffer], - remainingBuffer.length + nextBytesBuffer.length); - - const text = decoder.write(buffer); - remainingBytes = decoder.end(buffer); - - if(!moreToRead && remainingBytes.length > 0) { - // if for any reason, we have remaining bytes at the end - // of the stream, just discard - dont see why this should - // ever happen, but if it does, it could cause a stack overflow - remainingBytes = []; - } - - return text; - }; - }; - - const deserializeRow = (schema, rowText) => { - let currentPropIndex = 0; - let currentCharIndex = 0; - let currentValueText = ""; - let isEscaped = false; - const item = {}; - - const setCurrentProp = () => { - const currentProp = schema[currentPropIndex]; - const type = getType(currentProp.type); - const value = currentValueText === "" - ? type.getDefaultValue() - : type.safeParseValue( - currentValueText); - item[currentProp.name] = value; - }; - - while(currentPropIndex < schema.length) { - - if(currentCharIndex < rowText.length) { - const currentChar = rowText[currentCharIndex]; - if(isEscaped) { - if(currentChar === "r") { - currentValueText += "\r"; - } else { - currentValueText += currentChar; - } - isEscaped = false; - } else { - if(currentChar === ",") { - setCurrentProp(); - currentValueText = ""; - currentPropIndex++; - } else if(currentChar === "\\") { - isEscaped = true; - } else { - currentValueText += currentChar; - } - } - currentCharIndex++; - } else { - currentValueText = ""; - setCurrentProp(); - currentPropIndex++; - } - } - - return item; - }; - - const serializeItem = (schema, item) => { - - let rowText = ""; - - for(let prop of schema) { - const type = getType(prop.type); - const value = fp.has(prop.name)(item) - ? item[prop.name] - : type.getDefaultValue(); - - const valStr = type.stringify(value); - - for(let i = 0; i < valStr.length; i++) { - const currentChar = valStr[i]; - if(currentChar === "," - || currentChar === "\r" - || currentChar === "\\") { - rowText += "\\"; - } - - if(currentChar === "\r") { - rowText += "r"; - } else { - rowText += currentChar; - } - } - - rowText += ","; - } - - rowText += "\r"; - return rowText; - }; - - const readIndex$1 = async (hierarchy, datastore, index, indexedDataKey) => { - const records = []; - const doRead = iterateIndex( - async item => { - records.push(item); - return CONTINUE_READING_RECORDS; - }, - async () => records - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); - }; - - const searchIndex = async (hierarchy, datastore, index, indexedDataKey, searchPhrase) => { - const records = []; - const schema = generateSchema(hierarchy, index); - const doRead = iterateIndex( - async item => { - const idx = lunr(function () { - this.ref('key'); - for (const field of schema) { - this.field(field.name); - } - this.add(item); - }); - const searchResults = idx.search(searchPhrase); - if (searchResults.length === 1) { - item._searchResult = searchResults[0]; - records.push(item); - } - return CONTINUE_READING_RECORDS; - }, - async () => records - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); - }; - - const iterateIndex = (onGetItem, getFinalResult) => async (hierarchy, datastore, index, indexedDataKey) => { - try { - const readableStream = promiseReadableStream( - await datastore.readableFileStream(indexedDataKey) - ); - - const read = getIndexReader(hierarchy, index, readableStream); - await read(onGetItem); - return getFinalResult(); - } catch (e) { - if (await datastore.exists(indexedDataKey)) { - throw e; - } else { - await createIndexFile( - datastore, - indexedDataKey, - index, - ); - } - return []; - } - }; - - const getIndexDir = (hierarchy, indexKey) => { - - const parentKey = getParentKey(indexKey); - - if(parentKey === "") return indexKey; - if(parentKey === keySep) return indexKey; - - const recordInfo = getRecordInfo( - hierarchy, - parentKey); - - return recordInfo.child( - getLastPartInKey(indexKey)); - }; - - const listItems = app => async (indexKey, options) => { - indexKey = safeKey(indexKey); - return apiWrapper( - app, - events.indexApi.listItems, - permission.readIndex.isAuthorized(indexKey), - { indexKey, options }, - _listItems, app, indexKey, options, - ); - }; - - const defaultOptions = { rangeStartParams: null, rangeEndParams: null, searchPhrase: null }; - - const _listItems = async (app, indexKey, options = defaultOptions) => { - const { searchPhrase, rangeStartParams, rangeEndParams } = $({}, [ - fp.merge(options), - fp.merge(defaultOptions), - ]); - - const getItems = async indexedDataKey => (isNonEmptyString(searchPhrase) - ? await searchIndex( - app.hierarchy, - app.datastore, - indexNode, - indexedDataKey, - searchPhrase, - ) - : await readIndex$1( - app.hierarchy, - app.datastore, - indexNode, - indexedDataKey, - )); - - indexKey = safeKey(indexKey); - const indexNode = getExactNodeForKey(app.hierarchy)(indexKey); - const indexDir = getIndexDir(app.hierarchy, indexKey); - - if (!isIndex(indexNode)) { throw new Error('supplied key is not an index'); } - - if (isShardedIndex(indexNode)) { - const shardKeys = await getShardKeysInRange( - app, indexNode, indexDir, rangeStartParams, rangeEndParams, - ); - const items = []; - for (const k of shardKeys) { - items.push(await getItems(k)); - } - return fp.flatten(items); - } - return await getItems( - getUnshardedIndexDataKey(indexDir), - ); - }; - - const getContext = app => recordKey => { - recordKey = safeKey(recordKey); - return apiWrapperSync( - app, - events.recordApi.getContext, - permission.readRecord.isAuthorized(recordKey), - { recordKey }, - _getContext, app, recordKey, - ); - }; - - const _getContext = (app, recordKey) => { - recordKey = safeKey(recordKey); - const recordNode = getExactNodeForKey(app.hierarchy)(recordKey); - - const cachedReferenceIndexes = {}; - - const lazyLoadReferenceIndex = async (typeOptions) => { - if (!fp.has(typeOptions.indexNodeKey)(cachedReferenceIndexes)) { - cachedReferenceIndexes[typeOptions.indexNodeKey] = { - typeOptions, - data: await readReferenceIndex( - app, recordKey, typeOptions, - ), - }; - } - - return cachedReferenceIndexes[typeOptions.indexNodeKey]; - }; - - const getTypeOptions = typeOptions_or_fieldName => (fp.isString(typeOptions_or_fieldName) - ? findField(recordNode, typeOptions_or_fieldName) - .typeOptions - : typeOptions_or_fieldName); - - return { - referenceExists: async (typeOptions_or_fieldName, key) => { - const typeOptions = getTypeOptions(typeOptions_or_fieldName); - const { data } = await lazyLoadReferenceIndex(typeOptions); - return fp.some(i => i.key === key)(data); - }, - referenceOptions: async (typeOptions_or_fieldName) => { - const typeOptions = getTypeOptions(typeOptions_or_fieldName); - const { data } = await lazyLoadReferenceIndex(typeOptions); - return data; - }, - recordNode, - }; - }; - - const readReferenceIndex = async (app, recordKey, typeOptions) => { - const indexNode = getNode(app.hierarchy, typeOptions.indexNodeKey); - const indexKey = isGlobalIndex(indexNode) - ? indexNode.nodeKey() - : getIndexKey_BasedOnDecendant( - recordKey, indexNode, - ); - - const items = await listItems(app)(indexKey); - return $(items, [ - fp.map(i => ({ - key: i.key, - value: i[typeOptions.displayValue], - })), - ]); - }; - - const fieldParseError = (fieldName, value) => ({ - fields: [fieldName], - message: `Could not parse field ${fieldName}:${value}`, - }); - - const validateAllFieldParse = (record, recordNode) => $(recordNode.fields, [ - fp.map(f => ({ name: f.name, parseResult: validateFieldParse(f, record) })), - fp.reduce((errors, f) => { - if (f.parseResult.success) return errors; - errors.push( - fieldParseError(f.name, f.parseResult.value), - ); - return errors; - }, []), - ]); - - const validateAllTypeConstraints = async (record, recordNode, context) => { - const errors = []; - for (const field of recordNode.fields) { - $(await validateTypeConstraints$1(field, record, context), [ - fp.filter(isNonEmptyString), - fp.map(m => ({ message: m, fields: [field.name] })), - fp.each(e => errors.push(e)), - ]); - } - return errors; - }; - - const runRecordValidationRules = (record, recordNode) => { - const runValidationRule = (rule) => { - const isValid = compilerUtil.compileExpression(rule.expressionWhenValid); - const expressionContext = { record, _: ___default }; - return (isValid(expressionContext) - ? { valid: true } - : ({ - valid: false, - fields: rule.invalidFields, - message: rule.messageWhenInvalid, - })); - }; - - return $(recordNode.validationRules, [ - fp.map(runValidationRule), - fp.flatten, - fp.filter(r => r.valid === false), - fp.map(r => ({ fields: r.fields, message: r.message })), - ]); - }; - - const validate = app => async (record, context) => { - context = isNothing(context) - ? _getContext(app, record.key) - : context; - - const recordNode = getExactNodeForKey(app.hierarchy)(record.key); - const fieldParseFails = validateAllFieldParse(record, recordNode); - - // non parsing would cause further issues - exit here - if (!fp.isEmpty(fieldParseFails)) { return ({ isValid: false, errors: fieldParseFails }); } - - const recordValidationRuleFails = runRecordValidationRules(record, recordNode); - const typeContraintFails = await validateAllTypeConstraints(record, recordNode, context); - - if (fp.isEmpty(fieldParseFails) - && fp.isEmpty(recordValidationRuleFails) - && fp.isEmpty(typeContraintFails)) { - return ({ isValid: true, errors: [] }); - } - - return ({ - isValid: false, - errors: ___default.union(fieldParseFails, typeContraintFails, recordValidationRuleFails), - }); - }; - - const ensureCollectionIsInitialised = async (datastore, node, dir) => { - if (!await datastore.exists(dir)) { - await datastore.createFolder(dir); - await datastore.createFolder(joinKey(dir, node.nodeId)); - } - }; - - const initialiseRootCollections = async (datastore, hierarchy) => { - const rootCollectionRecord = allTrue( - n => isRoot(n.parent()), - isCollectionRecord, - ); - - const flathierarchy = getFlattenedHierarchy(hierarchy); - - const collectionRecords = $(flathierarchy, [ - fp.filter(rootCollectionRecord), - ]); - - for (const col of collectionRecords) { - await ensureCollectionIsInitialised( - datastore, - col, - col.collectionPathRegx() - ); - } - }; - - const initialiseChildCollections = async (app, recordInfo) => { - const childCollectionRecords = $(recordInfo.recordNode, [ - n => n.children, - fp.filter(isCollectionRecord), - ]); - - for (const child of childCollectionRecords) { - await ensureCollectionIsInitialised( - app.datastore, - child, - recordInfo.child(child.collectionName), - ); - } - }; - - const TRANSACTIONS_FOLDER = `${keySep}.transactions`; - const LOCK_FILENAME = 'lock'; - const LOCK_FILE_KEY = joinKey( - TRANSACTIONS_FOLDER, LOCK_FILENAME, - ); - const idSep = '$'; - - const isOfType = typ => trans => trans.transactionType === typ; - - const CREATE_RECORD_TRANSACTION = 'create'; - const UPDATE_RECORD_TRANSACTION = 'update'; - const DELETE_RECORD_TRANSACTION = 'delete'; - const BUILD_INDEX_TRANSACTION = 'build'; - - const isUpdate = isOfType(UPDATE_RECORD_TRANSACTION); - const isDelete = isOfType(DELETE_RECORD_TRANSACTION); - const isCreate = isOfType(CREATE_RECORD_TRANSACTION); - const isBuildIndex = isOfType(BUILD_INDEX_TRANSACTION); - - const keyToFolderName = nodeKey => getHashCode(nodeKey); - - const getTransactionId = (recordId, transactionType, uniqueId) => - `${recordId}${idSep}${transactionType}${idSep}${uniqueId}`; - - const buildIndexFolder = '.BUILD-'; - const nodeKeyHashFromBuildFolder = folder => folder.replace(buildIndexFolder, ''); - - const isBuildIndexFolder = key => getLastPartInKey(key).startsWith(buildIndexFolder); - - const IndexNodeKeyFolder = indexNodeKey => joinKey( - TRANSACTIONS_FOLDER, - buildIndexFolder + keyToFolderName(indexNodeKey), - ); - - const IndexNodeKeyBatchFolder = (indexNodeKey, count) => - joinKey(IndexNodeKeyFolder(indexNodeKey), Math.floor(count / BUILDINDEX_BATCH_COUNT).toString()); - - const BUILDINDEX_BATCH_COUNT = 1000; - const timeoutMilliseconds = 30 * 1000; // 30 secs - const maxLockRetries = 1; - - const transactionForCreateRecord = async (app, record) => await transaction( - app.datastore, CREATE_RECORD_TRANSACTION, - record.key, { record }, - getTransactionKey_Records, - ); - - const transactionForUpdateRecord = async (app, oldRecord, newRecord) => await transaction( - app.datastore, UPDATE_RECORD_TRANSACTION, - newRecord.key, { oldRecord, record: newRecord }, - getTransactionKey_Records, - ); - - const transactionForDeleteRecord = async (app, record) => await transaction( - app.datastore, DELETE_RECORD_TRANSACTION, - record.key, { record }, - getTransactionKey_Records, - ); - - const transactionForBuildIndex = async (app, indexNodeKey, recordKey, count) => { - const transactionFolder = IndexNodeKeyBatchFolder(indexNodeKey, count); - if (count % BUILDINDEX_BATCH_COUNT === 0) { - await app.datastore.createFolder(transactionFolder); - } - - return await transaction( - app.datastore, BUILD_INDEX_TRANSACTION, - recordKey, { recordKey }, - id => joinKey(transactionFolder, id), - ); - }; - - const createBuildIndexFolder = async (datastore, indexNodeKey) => await datastore.createFolder( - IndexNodeKeyFolder(indexNodeKey), - ); - - const getTransactionKey_Records = id => joinKey(TRANSACTIONS_FOLDER, id); - - const transaction = async (datastore, transactionType, recordKey, data, getTransactionKey) => { - const recordId = getLastPartInKey(recordKey); - const uniqueId = shortid.generate(); - const id = getTransactionId( - recordId, transactionType, uniqueId, - ); - - const key = getTransactionKey(id); - - const trans = { - transactionType, - recordKey, - ...data, - id, - }; - - await datastore.createJson( - key, trans, - ); - - return trans; - }; - - const initialiseIndex = async (datastore, dir, index) => { - const indexDir = joinKey(dir, index.name); - - await datastore.createFolder(indexDir); - - if (isShardedIndex(index)) { - await datastore.createFile( - getShardMapKey(indexDir), - '[]', - ); - } else { - await createIndexFile( - datastore, - getUnshardedIndexDataKey(indexDir), - index, - ); - } - }; - - const save = app => async (record, context) => apiWrapper( - app, - events.recordApi.save, - record.isNew - ? permission.createRecord.isAuthorized(record.key) - : permission.updateRecord.isAuthorized(record.key), { record }, - _save, app, record, context, false, - ); - - - const _save = async (app, record, context, skipValidation = false) => { - const recordClone = fp.cloneDeep(record); - if (!skipValidation) { - const validationResult = await validate(app)(recordClone, context); - if (!validationResult.isValid) { - await app.publish(events.recordApi.save.onInvalid, { record, validationResult }); - throw new BadRequestError(`Save : Record Invalid : ${ - JSON.stringify(validationResult.errors)}`); - } - } - - const recordInfo = getRecordInfo(app.hierarchy, record.key); - const { - recordNode, pathInfo, - recordJson, files, - } = recordInfo; - - if (recordClone.isNew) { - - if(!recordNode) - throw new Error("Cannot find node for " + record.key); - - const transaction = await transactionForCreateRecord( - app, recordClone, - ); - recordClone.transactionId = transaction.id; - await createRecordFolderPath(app.datastore, pathInfo); - await app.datastore.createFolder(files); - await app.datastore.createJson(recordJson, recordClone); - await initialiseReverseReferenceIndexes(app, recordInfo); - await initialiseAncestorIndexes(app, recordInfo); - await initialiseChildCollections(app, recordInfo); - await app.publish(events.recordApi.save.onRecordCreated, { - record: recordClone, - }); - } else { - const oldRecord = await _loadFromInfo(app, recordInfo); - const transaction = await transactionForUpdateRecord( - app, oldRecord, recordClone, - ); - recordClone.transactionId = transaction.id; - await app.datastore.updateJson( - recordJson, - recordClone, - ); - await app.publish(events.recordApi.save.onRecordUpdated, { - old: oldRecord, - new: recordClone, - }); - } - - await app.cleanupTransactions(); - - const returnedClone = fp.cloneDeep(recordClone); - returnedClone.isNew = false; - return returnedClone; - }; - - const initialiseAncestorIndexes = async (app, recordInfo) => { - for (const index of recordInfo.recordNode.indexes) { - const indexKey = recordInfo.child(index.name); - if (!await app.datastore.exists(indexKey)) { - await initialiseIndex(app.datastore, recordInfo.dir, index); - } - } - }; - - const initialiseReverseReferenceIndexes = async (app, recordInfo) => { - - const indexNodes = $(fieldsThatReferenceThisRecord(app, recordInfo.recordNode), [ - fp.map(f => $(f.typeOptions.reverseIndexNodeKeys, [ - fp.map(n => getNode( - app.hierarchy, - n, - )), - ])), - fp.flatten, - ]); - - for (const indexNode of indexNodes) { - await initialiseIndex( - app.datastore, recordInfo.dir, indexNode, - ); - } - }; - - const fieldsThatReferenceThisRecord = (app, recordNode) => $(app.hierarchy, [ - getFlattenedHierarchy, - fp.filter(isRecord), - fp.map(n => n.fields), - fp.flatten, - fp.filter(fieldReversesReferenceToNode(recordNode)), - ]); - - const createRecordFolderPath = async (datastore, pathInfo) => { - - const recursiveCreateFolder = async (subdirs, dirsThatNeedCreated=undefined) => { - - // iterate backwards through directory hierachy - // until we get to a folder that exists, then create the rest - // e.g - // - some/folder/here - // - some/folder - // - some - const thisFolder = joinKey(pathInfo.base, ...subdirs); - - if(await datastore.exists(thisFolder)) { - - let creationFolder = thisFolder; - for(let nextDir of (dirsThatNeedCreated || []) ) { - creationFolder = joinKey(creationFolder, nextDir); - await datastore.createFolder(creationFolder); - } - - } else if(!dirsThatNeedCreated || dirsThatNeedCreated.length > 0) { - - dirsThatNeedCreated = !dirsThatNeedCreated - ? [] - :dirsThatNeedCreated; - - await recursiveCreateFolder( - fp.take(subdirs.length - 1)(subdirs), - [...fp.takeRight(1)(subdirs), ...dirsThatNeedCreated] - ); - } - }; - - await recursiveCreateFolder(pathInfo.subdirs); - - return joinKey(pathInfo.base, ...pathInfo.subdirs); - - }; - - const deleteCollection = (app, disableCleanup = false) => async key => apiWrapper( - app, - events.collectionApi.delete, - permission.manageCollection.isAuthorized, - { key }, - _deleteCollection, app, key, disableCleanup, - ); - - /* - const recordNode = getCollectionNode(app.hierarchy, key); - - */ - - const _deleteCollection = async (app, key, disableCleanup) => { - key = safeKey(key); - const collectionDir = getCollectionDir(app.hierarchy, key); - await deleteRecords(app, key); - await deleteCollectionFolder(app, collectionDir); - if (!disableCleanup) { await app.cleanupTransactions(); } - }; - - const deleteCollectionFolder = async (app, dir) => - await app.datastore.deleteFolder(dir); - - const deleteRecords = async (app, key) => { - - const iterate = await getAllIdsIterator(app)(key); - - let ids = await iterate(); - while (!ids.done) { - if (ids.result.collectionKey === key) { - for (const id of ids.result.ids) { - await _deleteRecord( - app, - joinKey(key, id), - true, - ); - } - } - - ids = await iterate(); - } - }; - - const deleteRecord$1 = (app, disableCleanup = false) => async key => { - key = safeKey(key); - return apiWrapper( - app, - events.recordApi.delete, - permission.deleteRecord.isAuthorized(key), - { key }, - _deleteRecord, app, key, disableCleanup, - ); - }; - - // called deleteRecord because delete is a keyword - const _deleteRecord = async (app, key, disableCleanup) => { - const recordInfo = getRecordInfo(app.hierarchy, key); - key = recordInfo.key; - const node = getExactNodeForKey(app.hierarchy)(key); - - const record = await _load(app, key); - await transactionForDeleteRecord(app, record); - - for (const collectionRecord of node.children) { - const collectionKey = joinKey( - key, collectionRecord.collectionName, - ); - await _deleteCollection(app, collectionKey, true); - } - - await app.datastore.deleteFolder(recordInfo.dir); - - if (!disableCleanup) { await app.cleanupTransactions(); } - }; - - const uploadFile = app => async (recordKey, readableStream, relativeFilePath) => apiWrapper( - app, - events.recordApi.uploadFile, - permission.updateRecord.isAuthorized(recordKey), - { recordKey, readableStream, relativeFilePath }, - _uploadFile, app, recordKey, readableStream, relativeFilePath, - ); - - const _uploadFile = async (app, recordKey, readableStream, relativeFilePath) => { - if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); } - if (isNothing(relativeFilePath)) { throw new BadRequestError('file path not supplied'); } - if (!isLegalFilename(relativeFilePath)) { throw new BadRequestError('Illegal filename'); } - - const recordInfo = getRecordInfo(app.hierarchy, recordKey); - const record = await _loadFromInfo(app, recordInfo); - - const fullFilePath = safeGetFullFilePath( - recordInfo.dir, relativeFilePath, - ); - - const tempFilePath = `${fullFilePath}_${shortid.generate()}.temp`; - - const outputStream = await app.datastore.writableFileStream( - tempFilePath, - ); - - return new Promise((resolve,reject) => { - readableStream.pipe(outputStream); - outputStream.on('error', reject); - outputStream.on('finish', resolve); - }) - .then(() => app.datastore.getFileSize(tempFilePath)) - .then(size => { - const isExpectedFileSize = checkFileSizeAgainstFields( - app, record, relativeFilePath, size - ); - if (!isExpectedFileSize) { throw new BadRequestError(`Fields for ${relativeFilePath} do not have expected size: ${join(',')(incorrectFields)}`); } - - }) - .then(() => tryAwaitOrIgnore(app.datastore.deleteFile, fullFilePath)) - .then(() => app.datastore.renameFile(tempFilePath, fullFilePath)); - - }; - - const checkFileSizeAgainstFields = (app, record, relativeFilePath, expectedSize) => { - const recordNode = getExactNodeForKey(app.hierarchy)(record.key); - - const incorrectFileFields = $(recordNode.fields, [ - fp.filter(f => f.type === 'file' - && record[f.name].relativePath === relativeFilePath - && record[f.name].size !== expectedSize), - fp.map(f => f.name), - ]); - - const incorrectFileArrayFields = $(recordNode.fields, [ - fp.filter(a => a.type === 'array' - && $(record[a.name], [ - fp.some(f => record[f.name].relativePath === relativeFilePath - && record[f.name].size !== expectedSize), - ])), - fp.map(f => f.name), - ]); - - const incorrectFields = [ - ...incorrectFileFields, - ...incorrectFileArrayFields, - ]; - - if (incorrectFields.length > 0) { - return false; - } - - return true; - }; - - const safeGetFullFilePath = (recordDir, relativeFilePath) => { - const naughtyUser = () => { throw new ForbiddenError('naughty naughty'); }; - - if (relativeFilePath.startsWith('..')) naughtyUser(); - - const pathParts = splitKey(relativeFilePath); - - if (fp.includes('..')(pathParts)) naughtyUser(); - - const recordKeyParts = splitKey(recordDir); - - const fullPathParts = [ - ...recordKeyParts, - 'files', - ...fp.filter(p => p !== '.')(pathParts), - ]; - - return joinKey(fullPathParts); - }; - - const downloadFile = app => async (recordKey, relativePath) => apiWrapper( - app, - events.recordApi.uploadFile, - permission.readRecord.isAuthorized(recordKey), - { recordKey, relativePath },//remove dupe key 'recordKey' from object - _downloadFile, app, recordKey, relativePath, - ); - - - const _downloadFile = async (app, recordKey, relativePath) => { - if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); } - if (isNothing(relativePath)) { throw new BadRequestError('file path not supplied'); } - - const {dir} = getRecordInfo(app.hierarchy, recordKey); - return await app.datastore.readableFileStream( - safeGetFullFilePath( - dir, relativePath, - ), - ); - }; - - const customId = app => (nodeName, id) => { - const node = $(app.hierarchy, [ - getFlattenedHierarchy, - fp.find(n => n.name === nodeName), - ]); - - if (!node) throw new NotFoundError(`Cannot find node ${nodeName}`); - - return `${node.nodeId}-${id}`; - }; - - const setCustomId = app => (record, id) => { - record.id = customId(app)(record.type, id); - - const keyParts = splitKey(record.key); - - record.key = $(keyParts, [ - fp.take(keyParts.length - 1), - fp.union([record.id]), - joinKey, - ]); - - return record; - }; - - const api = app => ({ - getNew: getNew(app), - getNewChild: getNewChild(app), - save: save(app), - load: load(app), - delete: deleteRecord$1(app, false), - validate: validate(app), - getContext: getContext(app), - uploadFile: uploadFile(app), - downloadFile: downloadFile(app), - customId: customId(app), - setCustomId: setCustomId(app), - }); - - - const getRecordApi = app => api(app); - - const getAllowedRecordTypes = app => key => apiWrapperSync( - app, - events.collectionApi.getAllowedRecordTypes, - alwaysAuthorized, - { key }, - _getAllowedRecordTypes, app, key, - ); - - const _getAllowedRecordTypes = (app, key) => { - key = safeKey(key); - const node = getNodeForCollectionPath(app.hierarchy)(key); - return isNothing(node) ? [] : [node.name]; - }; - - const getCollectionApi = app => ({ - getAllowedRecordTypes: getAllowedRecordTypes(app), - getAllIdsIterator: getAllIdsIterator(app), - delete: deleteCollection(app), - }); - - /** rebuilds an index - * @param {object} app - the application container - * @param {string} indexNodeKey - node key of the index, which the index belongs to - */ - const buildIndex = app => async indexNodeKey => apiWrapper( - app, - events.indexApi.buildIndex, - permission.manageIndex.isAuthorized, - { indexNodeKey }, - _buildIndex, app, indexNodeKey, - ); - - const _buildIndex = async (app, indexNodeKey) => { - const indexNode = getNode(app.hierarchy, indexNodeKey); - - await createBuildIndexFolder(app.datastore, indexNodeKey); - - if (!isIndex(indexNode)) { throw new BadRequestError('BuildIndex: must supply an indexnode'); } - - if (indexNode.indexType === 'reference') { - await buildReverseReferenceIndex( - app, indexNode, - ); - } else { - await buildHeirarchalIndex( - app, indexNode, - ); - } - - await app.cleanupTransactions(); - }; - - const buildReverseReferenceIndex = async (app, indexNode) => { - // Iterate through all referencING records, - // and update referenced index for each record - let recordCount = 0; - const referencingNodes = $(app.hierarchy, [ - getFlattenedHierarchy, - fp.filter(n => isRecord(n) - && fp.some(fieldReversesReferenceToIndex(indexNode))(n.fields)), - ]); - - const createTransactionsForReferencingNode = async (referencingNode) => { - const iterateReferencingNodes = await getAllIdsIterator(app)(referencingNode.collectionNodeKey()); - - let referencingIdIterator = await iterateReferencingNodes(); - while (!referencingIdIterator.done) { - const { result } = referencingIdIterator; - for (const id of result.ids) { - const recordKey = joinKey(result.collectionKey, id); - await transactionForBuildIndex(app, indexNode.nodeKey(), recordKey, recordCount); - recordCount++; - } - referencingIdIterator = await iterateReferencingNodes(); - } - }; - - for (const referencingNode of referencingNodes) { - await createTransactionsForReferencingNode(referencingNode); - } - }; - - /* - const getAllowedParentCollectionNodes = (hierarchy, indexNode) => $(getAllowedRecordNodesForIndex(hierarchy, indexNode), [ - map(n => n.parent()), - ]); - */ - - const buildHeirarchalIndex = async (app, indexNode) => { - let recordCount = 0; - - const createTransactionsForIds = async (collectionKey, ids) => { - for (const recordId of ids) { - const recordKey = joinKey(collectionKey, recordId); - - const recordNode = getRecordNodeById( - app.hierarchy, - recordId, - ); - - if (recordNodeApplies(indexNode)(recordNode)) { - await transactionForBuildIndex( - app, indexNode.nodeKey(), - recordKey, recordCount, - ); - recordCount++; - } - } - }; - - - const collectionRecords = getAllowedRecordNodesForIndex(app.hierarchy, indexNode); - - for (const targetCollectionRecordNode of collectionRecords) { - const allIdsIterator = await getAllIdsIterator(app)(targetCollectionRecordNode.collectionNodeKey()); - - let allIds = await allIdsIterator(); - while (allIds.done === false) { - await createTransactionsForIds( - allIds.result.collectionKey, - allIds.result.ids, - ); - allIds = await allIdsIterator(); - } - } - - return recordCount; - }; - - // const chooseChildRecordNodeByKey = (collectionNode, recordId) => find(c => recordId.startsWith(c.nodeId))(collectionNode.children); - - const recordNodeApplies = indexNode => recordNode => fp.includes(recordNode.nodeId)(indexNode.allowedRecordNodeIds); - - const aggregates = app => async (indexKey, rangeStartParams = null, rangeEndParams = null) => apiWrapper( - app, - events.indexApi.aggregates, - permission.readIndex.isAuthorized(indexKey), - { indexKey, rangeStartParams, rangeEndParams }, - _aggregates, app, indexKey, rangeStartParams, rangeEndParams, - ); - - const _aggregates = async (app, indexKey, rangeStartParams, rangeEndParams) => { - indexKey = safeKey(indexKey); - const indexNode = getExactNodeForKey(app.hierarchy)(indexKey); - const indexDir = getIndexDir(app.hierarchy, indexKey); - - if (!isIndex(indexNode)) { throw new BadRequestError('supplied key is not an index'); } - - if (isShardedIndex(indexNode)) { - const shardKeys = await getShardKeysInRange( - app, indexNode, indexDir, rangeStartParams, rangeEndParams, - ); - let aggregateResult = null; - for (const k of shardKeys) { - const shardResult = await getAggregates(app.hierarchy, app.datastore, indexNode, k); - if (aggregateResult === null) { - aggregateResult = shardResult; - } else { - aggregateResult = mergeShardAggregate( - aggregateResult, - shardResult, - ); - } - } - return aggregateResult; - } - return await getAggregates( - app.hierarchy, - app.datastore, - indexNode, - getUnshardedIndexDataKey(indexDir), - ); - }; - - const mergeShardAggregate = (totals, shard) => { - const mergeGrouping = (tot, shr) => { - tot.count += shr.count; - for (const aggName in tot) { - if (aggName === 'count') continue; - const totagg = tot[aggName]; - const shragg = shr[aggName]; - totagg.sum += shragg.sum; - totagg.max = totagg.max > shragg.max - ? totagg.max - : shragg.max; - totagg.min = totagg.min < shragg.min - ? totagg.min - : shragg.min; - totagg.mean = totagg.sum / tot.count; - } - return tot; - }; - - for (const aggGroupDef in totals) { - for (const grouping in shard[aggGroupDef]) { - const groupingTotal = totals[aggGroupDef][grouping]; - totals[aggGroupDef][grouping] = fp.isUndefined(groupingTotal) - ? shard[aggGroupDef][grouping] - : mergeGrouping( - totals[aggGroupDef][grouping], - shard[aggGroupDef][grouping], - ); - } - } - - return totals; - }; - - const getAggregates = async (hierarchy, datastore, index, indexedDataKey) => { - const aggregateResult = {}; - const doRead = iterateIndex( - async item => { - applyItemToAggregateResult( - index, aggregateResult, item, - ); - return CONTINUE_READING_RECORDS; - }, - async () => aggregateResult - ); - - return await doRead(hierarchy, datastore, index, indexedDataKey); - }; - - - const applyItemToAggregateResult = (indexNode, result, item) => { - const getInitialAggregateResult = () => ({ - sum: 0, mean: null, max: null, min: null, - }); - - const applyAggregateResult = (agg, existing, count) => { - const value = compilerUtil.compileCode(agg.aggregatedValue)({ record: item }); - - if (!fp.isNumber(value)) return existing; - - existing.sum += value; - existing.max = value > existing.max || existing.max === null - ? value - : existing.max; - existing.min = value < existing.min || existing.min === null - ? value - : existing.min; - existing.mean = existing.sum / count; - return existing; - }; - - for (const aggGroup of indexNode.aggregateGroups) { - if (!fp.has(aggGroup.name)(result)) { - result[aggGroup.name] = {}; - } - - const thisGroupResult = result[aggGroup.name]; - - if (isNonEmptyString(aggGroup.condition)) { - if (!compilerUtil.compileExpression(aggGroup.condition)({ record: item })) { - continue; - } - } - - let group = isNonEmptyString(aggGroup.groupBy) - ? compilerUtil.compileCode(aggGroup.groupBy)({ record: item }) - : 'all'; - if (!isNonEmptyString(group)) { - group = '(none)'; - } - - if (!fp.has(group)(thisGroupResult)) { - thisGroupResult[group] = { count: 0 }; - for (const agg of aggGroup.aggregates) { - thisGroupResult[group][agg.name] = getInitialAggregateResult(); - } - } - - thisGroupResult[group].count++; - - for (const agg of aggGroup.aggregates) { - const existingValues = thisGroupResult[group][agg.name]; - thisGroupResult[group][agg.name] = applyAggregateResult( - agg, existingValues, - thisGroupResult[group].count, - ); - } - } - }; - - const getIndexApi = app => ({ - listItems: listItems(app), - buildIndex: buildIndex(app), - aggregates: aggregates(app), - }); - - const createNodeErrors = { - indexCannotBeParent: 'Index template cannot be a parent', - allNonRootNodesMustHaveParent: 'Only the root node may have no parent', - indexParentMustBeRecordOrRoot: 'An index may only have a record or root as a parent', - aggregateParentMustBeAnIndex: 'aggregateGroup parent must be an index', - }; - - const pathRegxMaker = node => () => node.nodeKey().replace(/{id}/g, '[a-zA-Z0-9_-]+'); - - const nodeKeyMaker = node => () => switchCase( - - [n => isRecord(n) && !isSingleRecord(n), - n => joinKey( - node.parent().nodeKey(), - node.collectionName, - `${n.nodeId}-{id}`, - )], - - [isRoot, - fp.constant('/')], - - [defaultCase, - n => joinKey(node.parent().nodeKey(), n.name)], - - )(node); - - - const validate$1 = parent => (node) => { - if (isIndex(node) - && isSomething(parent) - && !isRoot(parent) - && !isRecord(parent)) { - throw new BadRequestError(createNodeErrors.indexParentMustBeRecordOrRoot); - } - - if (isaggregateGroup(node) - && isSomething(parent) - && !isIndex(parent)) { - throw new BadRequestError(createNodeErrors.aggregateParentMustBeAnIndex); - } - - if (isNothing(parent) && !isRoot(node)) { throw new BadRequestError(createNodeErrors.allNonRootNodesMustHaveParent); } - - return node; - }; - - const construct = parent => (node) => { - node.nodeKey = nodeKeyMaker(node); - node.pathRegx = pathRegxMaker(node); - node.parent = fp.constant(parent); - node.isRoot = () => isNothing(parent) - && node.name === 'root' - && node.type === 'root'; - if (isCollectionRecord(node)) { - node.collectionNodeKey = () => joinKey( - parent.nodeKey(), node.collectionName, - ); - node.collectionPathRegx = () => joinKey( - parent.pathRegx(), node.collectionName, - ); - } - return node; - }; - - const addToParent = (obj) => { - const parent = obj.parent(); - if (isSomething(parent)) { - if (isIndex(obj)) - // Q: why are indexes not children ? - // A: because they cannot have children of their own. - { - parent.indexes.push(obj); - } - else if (isaggregateGroup(obj)) - { - parent.aggregateGroups.push(obj); - } else { - parent.children.push(obj); - } - - if (isRecord(obj)) { - const defaultIndex = _.find( - parent.indexes, - i => i.name === `${parent.name}_index`, - ); - if (defaultIndex) { - defaultIndex.allowedRecordNodeIds.push(obj.nodeId); - } - } - } - return obj; - }; - - const constructNode = (parent, obj) => $(obj, [ - construct(parent), - validate$1(parent), - addToParent, - ]); - - const getNodeId = (parentNode) => { - // this case is handled better elsewhere - if (!parentNode) return null; - const findRoot = n => (isRoot(n) ? n : findRoot(n.parent())); - const root = findRoot(parentNode); - - return ($(root, [ - getFlattenedHierarchy, - fp.map(n => n.nodeId), - fp.max]) + 1); - }; - - const constructHierarchy = (node, parent) => { - construct(parent)(node); - if (node.indexes) { - _.each(node.indexes, - child => constructHierarchy(child, node)); - } - if (node.aggregateGroups) { - _.each(node.aggregateGroups, - child => constructHierarchy(child, node)); - } - if (node.children && node.children.length > 0) { - _.each(node.children, - child => constructHierarchy(child, node)); - } - if (node.fields) { - _.each(node.fields, - f => _.each(f.typeOptions, (val, key) => { - const def = all$1[f.type].optionDefinitions[key]; - if (!def) { - // unknown typeOption - delete f.typeOptions[key]; - } else { - f.typeOptions[key] = def.parse(val); - } - })); - } - return node; - }; - - - const getNewRootLevel = () => construct()({ - name: 'root', - type: 'root', - children: [], - pathMaps: [], - indexes: [], - nodeId: 0, - }); - - const _getNewRecordTemplate = (parent, name, createDefaultIndex, isSingle) => { - const node = constructNode(parent, { - name, - type: 'record', - fields: [], - children: [], - validationRules: [], - nodeId: getNodeId(parent), - indexes: [], - estimatedRecordCount: isRecord(parent) ? 500 : 1000000, - collectionName: '', - isSingle, - }); - - if (createDefaultIndex) { - const defaultIndex = getNewIndexTemplate(parent); - defaultIndex.name = `${name}_index`; - defaultIndex.allowedRecordNodeIds.push(node.nodeId); - } - - return node; - }; - - const getNewRecordTemplate = (parent, name = '', createDefaultIndex = true) => _getNewRecordTemplate(parent, name, createDefaultIndex, false); - - const getNewSingleRecordTemplate = parent => _getNewRecordTemplate(parent, '', false, true); - - const getNewIndexTemplate = (parent, type = 'ancestor') => constructNode(parent, { - name: '', - type: 'index', - map: 'return {...record};', - filter: '', - indexType: type, - getShardName: '', - getSortKey: 'record.id', - aggregateGroups: [], - allowedRecordNodeIds: [], - nodeId: getNodeId(parent), - }); - - const getNewAggregateGroupTemplate = index => constructNode(index, { - name: '', - type: 'aggregateGroup', - groupBy: '', - aggregates: [], - condition: '', - nodeId: getNodeId(index), - }); - - const getNewAggregateTemplate = (set) => { - const aggregatedValue = { - name: '', - aggregatedValue: '', - }; - set.aggregates.push(aggregatedValue); - return aggregatedValue; - }; - - const fieldErrors = { - AddFieldValidationFailed: 'Add field validation: ', - }; - - const allowedTypes = () => fp.keys(all$1); - - const getNewField = type => ({ - name: '', // how field is referenced internally - type, - typeOptions: getDefaultOptions$1(type), - label: '', // how field is displayed - getInitialValue: 'default', // function that gets value when initially created - getUndefinedValue: 'default', // function that gets value when field undefined on record - }); - - const fieldRules = allFields => [ - makerule('name', 'field name is not set', - f => isNonEmptyString(f.name)), - makerule('type', 'field type is not set', - f => isNonEmptyString(f.type)), - makerule('label', 'field label is not set', - f => isNonEmptyString(f.label)), - makerule('getInitialValue', 'getInitialValue function is not set', - f => isNonEmptyString(f.getInitialValue)), - makerule('getUndefinedValue', 'getUndefinedValue function is not set', - f => isNonEmptyString(f.getUndefinedValue)), - makerule('name', 'field name is duplicated', - f => isNothingOrEmpty(f.name) - || fp.countBy('name')(allFields)[f.name] === 1), - makerule('type', 'type is unknown', - f => isNothingOrEmpty(f.type) - || fp.some(t => f.type === t)(allowedTypes())), - ]; - - const typeOptionsRules = (field) => { - const type = all$1[field.type]; - if (isNothing(type)) return []; - - const def = optName => type.optionDefinitions[optName]; - - return $(field.typeOptions, [ - fp.keys, - fp.filter(o => isSomething(def(o)) - && isSomething(def(o).isValid)), - fp.map(o => makerule( - `typeOptions.${o}`, - `${def(o).requirementDescription}`, - field => def(o).isValid(field.typeOptions[o]), - )), - ]); - }; - - const validateField = allFields => (field) => { - const everySingleField = fp.includes(field)(allFields) ? allFields : [...allFields, field]; - return applyRuleSet([...fieldRules(everySingleField), ...typeOptionsRules(field)])(field); - }; - - const validateAllFields = recordNode => $(recordNode.fields, [ - fp.map(validateField(recordNode.fields)), - fp.flatten, - ]); - - const addField = (recordTemplate, field) => { - if (isNothingOrEmpty(field.label)) { - field.label = field.name; - } - const validationMessages = validateField([...recordTemplate.fields, field])(field); - if (validationMessages.length > 0) { - const errors = fp.map(m => m.error)(validationMessages); - throw new BadRequestError(`${fieldErrors.AddFieldValidationFailed} ${errors.join(', ')}`); - } - recordTemplate.fields.push(field); - }; - - const getNewRecordValidationRule = (invalidFields, - messageWhenInvalid, - expressionWhenValid) => ({ - invalidFields, messageWhenInvalid, expressionWhenValid, - }); - - const getStaticValue = switchCase( - [fp.isNumber, v => v.toString()], - [fp.isBoolean, v => v.toString()], - [fp.defaultCase, v => `'${v}'`], - ); - - const commonRecordValidationRules = ({ - - fieldNotEmpty: fieldName => getNewRecordValidationRule( - [fieldName], - `${fieldName} is empty`, - `!_.isEmpty(record['${fieldName}'])`, - ), - - fieldBetween: (fieldName, min, max) => getNewRecordValidationRule( - [fieldName], - `${fieldName} must be between ${min.toString()} and ${max.toString()}`, - `record['${fieldName}'] >= ${getStaticValue(min)} && record['${fieldName}'] <= ${getStaticValue(max)} `, - ), - - fieldGreaterThan: (fieldName, min, max) => getNewRecordValidationRule( - [fieldName], - `${fieldName} must be greater than ${min.toString()} and ${max.toString()}`, - `record['${fieldName}'] >= ${getStaticValue(min)} `, - ), - }); - - const addRecordValidationRule = recordNode => rule => recordNode.validationRules.push(rule); - - const createTrigger = () => ({ - actionName: '', - eventName: '', - // function, has access to event context, - // returns object that is used as parameter to action - // only used if triggered by event - optionsCreator: '', - // action runs if true, - // has access to event context - condition: '', - }); - - const createAction = () => ({ - name: '', - behaviourSource: '', - // name of function in actionSource - behaviourName: '', - // parameter passed into behaviour. - // any other parms passed at runtime e.g. - // by trigger, or manually, will be merged into this - initialOptions: {}, - }); - - const aggregateRules = [ - makerule('name', 'choose a name for the aggregate', - a => isNonEmptyString(a.name)), - makerule('aggregatedValue', 'aggregatedValue does not compile', - a => fp.isEmpty(a.aggregatedValue) - || executesWithoutException( - () => compilerUtil.compileCode(a.aggregatedValue), - )), - ]; - - const validateAggregate = aggregate => applyRuleSet(aggregateRules)(aggregate); - - const validateAllAggregates = all => $(all, [ - fp.map(validateAggregate), - fp.flatten, - ]); - - const ruleSet = (...sets) => fp.constant(fp.flatten([...sets])); - - const commonRules = [ - makerule('name', 'node name is not set', - node => stringNotEmpty(node.name)), - makerule('type', 'node type not recognised', - anyTrue(isRecord, isRoot, isIndex, isaggregateGroup)), - ]; - - const recordRules = [ - makerule('fields', 'no fields have been added to the record', - node => isNonEmptyArray(node.fields)), - makerule('validationRules', "validation rule is missing a 'messageWhenValid' member", - node => fp.every(r => fp.has('messageWhenInvalid')(r))(node.validationRules)), - makerule('validationRules', "validation rule is missing a 'expressionWhenValid' member", - node => fp.every(r => fp.has('expressionWhenValid')(r))(node.validationRules)), - ]; - - - const aggregateGroupRules = [ - makerule('condition', 'condition does not compile', - a => fp.isEmpty(a.condition) - || executesWithoutException( - () => compilerUtil.compileExpression(a.condition), - )), - ]; - - const getRuleSet = node => switchCase( - - [isRecord, ruleSet( - commonRules, - recordRules, - )], - - [isIndex, ruleSet( - commonRules, - indexRuleSet, - )], - - [isaggregateGroup, ruleSet( - commonRules, - aggregateGroupRules, - )], - - [defaultCase, ruleSet(commonRules, [])], - )(node); - - const validateNode = node => applyRuleSet(getRuleSet(node))(node); - - const validateAll = (appHierarchy) => { - const flattened = getFlattenedHierarchy( - appHierarchy, - ); - - const duplicateNameRule = makerule( - 'name', 'node names must be unique under shared parent', - n => fp.filter(f => f.parent() === n.parent() - && f.name === n.name)(flattened).length === 1, - ); - - const duplicateNodeKeyErrors = $(flattened, [ - fp.map(n => applyRuleSet([duplicateNameRule])(n)), - fp.filter(isSomething), - fp.flatten, - ]); - - const fieldErrors = $(flattened, [ - fp.filter(isRecord), - fp.map(validateAllFields), - fp.flatten, - ]); - - const aggregateErrors = $(flattened, [ - fp.filter(isaggregateGroup), - fp.map(s => validateAllAggregates( - s.aggregates, - )), - fp.flatten, - ]); - - return $(flattened, [ - fp.map(validateNode), - fp.flatten, - fp.union(duplicateNodeKeyErrors), - fp.union(fieldErrors), - fp.union(aggregateErrors), - ]); - }; - - const actionRules = [ - makerule('name', 'action must have a name', - a => isNonEmptyString(a.name)), - makerule('behaviourName', 'must supply a behaviour name to the action', - a => isNonEmptyString(a.behaviourName)), - makerule('behaviourSource', 'must supply a behaviour source for the action', - a => isNonEmptyString(a.behaviourSource)), - ]; - - const duplicateActionRule = makerule('', 'action name must be unique', () => {}); - - const validateAction = action => applyRuleSet(actionRules)(action); - - - const validateActions = (allActions) => { - const duplicateActions = $(allActions, [ - fp.filter(a => fp.filter(a2 => a2.name === a.name)(allActions).length > 1), - fp.map(a => validationError(duplicateActionRule, a)), - ]); - - const errors = $(allActions, [ - fp.map(validateAction), - fp.flatten, - fp.union(duplicateActions), - fp.uniqBy('name'), - ]); - - return errors; - }; - - const triggerRules = actions => ([ - makerule('actionName', 'must specify an action', - t => isNonEmptyString(t.actionName)), - makerule('eventName', 'must specify and event', - t => isNonEmptyString(t.eventName)), - makerule('actionName', 'specified action not supplied', - t => !t.actionName - || fp.some(a => a.name === t.actionName)(actions)), - makerule('eventName', 'invalid Event Name', - t => !t.eventName - || fp.includes(t.eventName)(eventsList)), - makerule('optionsCreator', 'Options Creator does not compile - check your expression', - (t) => { - if (!t.optionsCreator) return true; - try { - compilerUtil.compileCode(t.optionsCreator); - return true; - } catch (_) { return false; } - }), - makerule('condition', 'Trigger condition does not compile - check your expression', - (t) => { - if (!t.condition) return true; - try { - compilerUtil.compileExpression(t.condition); - return true; - } catch (_) { return false; } - }), - ]); - - const validateTrigger = (trigger, allActions) => { - const errors = applyRuleSet(triggerRules(allActions))(trigger); - - return errors; - }; - - const validateTriggers = (triggers, allActions) => $(triggers, [ - fp.map(t => validateTrigger(t, allActions)), - fp.flatten, - ]); - - const getApplicationDefinition = datastore => async () => { - const exists = await datastore.exists(appDefinitionFile); - - if (!exists) throw new Error('Application definition does not exist'); - - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.hierarchy = constructHierarchy( - appDefinition.hierarchy, - ); - return appDefinition; - }; - - const saveApplicationHierarchy = app => async hierarchy => apiWrapper( - app, - events.templateApi.saveApplicationHierarchy, - permission.writeTemplates.isAuthorized, - { hierarchy }, - _saveApplicationHierarchy, app.datastore, hierarchy, - ); - - - const _saveApplicationHierarchy = async (datastore, hierarchy) => { - const validationErrors = await validateAll(hierarchy); - if (validationErrors.length > 0) { - throw new Error(`Hierarchy is invalid: ${_.join( - validationErrors.map(e => `${e.item.nodeKey ? e.item.nodeKey() : ''} : ${e.error}`), - ',', - )}`); - } - - if (await datastore.exists(appDefinitionFile)) { - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.hierarchy = hierarchy; - await datastore.updateJson(appDefinitionFile, appDefinition); - } else { - await datastore.createFolder('/.config'); - const appDefinition = { actions: [], triggers: [], hierarchy }; - await datastore.createJson(appDefinitionFile, appDefinition); - } - }; - - const saveActionsAndTriggers = app => async (actions, triggers) => apiWrapper( - app, - events.templateApi.saveActionsAndTriggers, - permission.writeTemplates.isAuthorized, - { actions, triggers }, - _saveActionsAndTriggers, app.datastore, actions, triggers, - ); - - const _saveActionsAndTriggers = async (datastore, actions, triggers) => { - if (await datastore.exists(appDefinitionFile)) { - const appDefinition = await datastore.loadJson(appDefinitionFile); - appDefinition.actions = actions; - appDefinition.triggers = triggers; - - const actionValidErrs = fp.map(e => e.error)(validateActions(actions)); - - if (actionValidErrs.length > 0) { - throw new BadRequestError(`Actions are invalid: ${_.join(actionValidErrs, ', ')}`); - } - - const triggerValidErrs = fp.map(e => e.error)(validateTriggers(triggers, actions)); - - if (triggerValidErrs.length > 0) { - throw new BadRequestError(`Triggers are invalid: ${_.join(triggerValidErrs, ', ')}`); - } - - await datastore.updateJson(appDefinitionFile, appDefinition); - } else { - throw new BadRequestError('Cannot save actions: Application definition does not exist'); - } - }; - - const getBehaviourSources = async (datastore) => { - await datastore.loadFile('/.config/behaviourSources.js'); - }; - - const api$1 = app => ({ - - getApplicationDefinition: getApplicationDefinition(app.datastore), - saveApplicationHierarchy: saveApplicationHierarchy(app), - saveActionsAndTriggers: saveActionsAndTriggers(app), - getBehaviourSources: () => getBehaviourSources(app.datastore), - getNewRootLevel, - constructNode, - getNewIndexTemplate, - getNewRecordTemplate, - getNewField, - validateField, - addField, - fieldErrors, - getNewRecordValidationRule, - commonRecordValidationRules, - addRecordValidationRule, - createAction, - createTrigger, - validateActions, - validateTrigger, - getNewAggregateGroupTemplate, - getNewAggregateTemplate, - constructHierarchy, - getNewSingleRecordTemplate, - allTypes: all$1, - validateNode, - validateAll, - validateTriggers, - }); - - - const getTemplateApi = app => api$1(app); - - const getUsers = app => async () => apiWrapper( - app, - events.authApi.getUsers, - permission.listUsers.isAuthorized, - {}, - _getUsers, app, - ); - - const _getUsers = async app => $(await app.datastore.loadJson(USERS_LIST_FILE), [ - fp.map(stripUserOfSensitiveStuff), - ]); - - const loadAccessLevels = app => async () => apiWrapper( - app, - events.authApi.loadAccessLevels, - permission.listAccessLevels.isAuthorized, - {}, - _loadAccessLevels, app, - ); - - const _loadAccessLevels = async app => await app.datastore.loadJson(ACCESS_LEVELS_FILE); - - const dummyHash = '$argon2i$v=19$m=4096,t=3,p=1$UZRo409UYBGjHJS3CV6Uxw$rU84qUqPeORFzKYmYY0ceBLDaPO+JWSH4PfNiKXfIKk'; - - const authenticate = app => async (username, password) => apiWrapper( - app, - events.authApi.authenticate, - alwaysAuthorized, - { username, password }, - _authenticate, app, username, password, - ); - - const _authenticate = async (app, username, password) => { - if (isNothingOrEmpty(username) || isNothingOrEmpty(password)) { return null; } - - const allUsers = await _getUsers(app); - let user = getUserByName( - allUsers, - username, - ); - - const notAUser = 'not-a-user'; - // continue with non-user - so time to verify remains consistent - // with verification of a valid user - if (!user || !user.enabled) { user = notAUser; } - - let userAuth; - try { - userAuth = await app.datastore.loadJson( - userAuthFile(username), - ); - } catch (_) { - userAuth = { accessLevels: [], passwordHash: dummyHash }; - } - - const permissions = await buildUserPermissions(app, user.accessLevels); - - const verified = await app.crypto.verify( - userAuth.passwordHash, - password, - ); - - if (user === notAUser) { return null; } - - return verified - ? { - ...user, permissions, temp: false, isUser: true, - } - : null; - }; - - const authenticateTemporaryAccess = app => async (tempAccessCode) => { - if (isNothingOrEmpty(tempAccessCode)) { return null; } - - const temp = parseTemporaryCode(tempAccessCode); - let user = $(await _getUsers(app), [ - fp.find(u => u.temporaryAccessId === temp.id), - ]); - - const notAUser = 'not-a-user'; - if (!user || !user.enabled) { user = notAUser; } - - let userAuth; - try { - userAuth = await app.datastore.loadJson( - userAuthFile(user.name), - ); - } catch (e) { - userAuth = { - temporaryAccessHash: dummyHash, - temporaryAccessExpiryEpoch: (await app.getEpochTime() + 10000), - }; - } - - if (userAuth.temporaryAccessExpiryEpoch < await app.getEpochTime()) { user = notAUser; } - - const tempCode = !temp.code ? shortid.generate() : temp.code; - const verified = await app.crypto.verify( - userAuth.temporaryAccessHash, - tempCode, - ); - - if (user === notAUser) { return null; } - - return verified - ? { - ...user, - permissions: [], - temp: true, - isUser: true, - } - : null; - }; - - const buildUserPermissions = async (app, userAccessLevels) => { - const allAccessLevels = await _loadAccessLevels(app); - - return $(allAccessLevels.levels, [ - fp.filter(l => fp.some(ua => l.name === ua)(userAccessLevels)), - fp.map(l => l.permissions), - fp.flatten, - ]); - }; - - const createTemporaryAccess$1 = app => async userName => apiWrapper( - app, - events.authApi.createTemporaryAccess, - alwaysAuthorized, - { userName }, - _createTemporaryAccess, app, userName, - ); - - const _createTemporaryAccess = async (app, userName) => { - const tempCode = await getTemporaryCode(app); - - const lock = await getLock( - app, USERS_LOCK_FILE, 1000, 2, - ); - - if (isNolock(lock)) { throw new Error('Unable to create temporary access, could not get lock - try again'); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - - const user = getUserByName(users, userName); - user.temporaryAccessId = tempCode.temporaryAccessId; - - await app.datastore.updateJson( - USERS_LIST_FILE, - users, - ); - } finally { - await releaseLock(app, lock); - } - - const userAuth = await app.datastore.loadJson( - userAuthFile(userName), - ); - userAuth.temporaryAccessHash = tempCode.temporaryAccessHash; - - userAuth.temporaryAccessExpiryEpoch = tempCode.temporaryAccessExpiryEpoch; - - await app.datastore.updateJson( - userAuthFile(userName), - userAuth, - ); - - return tempCode.tempCode; - }; - - const getTemporaryCode = async (app) => { - const tempCode = shortid.generate() - + shortid.generate() - + shortid.generate() - + shortid.generate(); - - const tempId = shortid.generate(); - - return { - temporaryAccessHash: await app.crypto.hash( - tempCode, - ), - temporaryAccessExpiryEpoch: - (await app.getEpochTime()) + tempCodeExpiryLength, - tempCode: `tmp:${tempId}:${tempCode}`, - temporaryAccessId: tempId, - }; - }; - - const userRules = allUsers => [ - makerule('name', 'username must be set', - u => isNonEmptyString(u.name)), - makerule('accessLevels', 'user must have at least one access level', - u => u.accessLevels.length > 0), - makerule('name', 'username must be unique', - u => fp.filter(u2 => insensitiveEquals(u2.name, u.name))(allUsers).length === 1), - makerule('accessLevels', 'access levels must only contain stings', - u => all(isNonEmptyString)(u.accessLevels)), - ]; - - const validateUser = () => (allusers, user) => applyRuleSet(userRules(allusers))(user); - - const getNewUser = app => () => apiWrapperSync( - app, - events.authApi.getNewUser, - permission.createUser.isAuthorized, - {}, - _getNewUser, app, - ); - - const _getNewUser = () => ({ - name: '', - accessLevels: [], - enabled: true, - temporaryAccessId: '', - }); - - const getNewUserAuth = app => () => apiWrapperSync( - app, - events.authApi.getNewUserAuth, - permission.createUser.isAuthorized, - {}, - _getNewUserAuth, app, - ); - - const _getNewUserAuth = () => ({ - passwordHash: '', - temporaryAccessHash: '', - temporaryAccessExpiryEpoch: 0, - }); - - const isValidPassword = app => password => apiWrapperSync( - app, - events.authApi.isValidPassword, - alwaysAuthorized, - { password }, - _isValidPassword, app, password, - ); - - const _isValidPassword = (app, password) => scorePassword(password).score > 30; - - const changeMyPassword = app => async (currentPw, newpassword) => apiWrapper( - app, - events.authApi.changeMyPassword, - alwaysAuthorized, - { currentPw, newpassword }, - _changeMyPassword, app, currentPw, newpassword, - ); - - const _changeMyPassword = async (app, currentPw, newpassword) => { - const existingAuth = await app.datastore.loadJson( - userAuthFile(app.user.name), - ); - - if (isSomething(existingAuth.passwordHash)) { - const verified = await app.crypto.verify( - existingAuth.passwordHash, - currentPw, - ); - - if (verified) { - await await doSet( - app, existingAuth, - app.user.name, newpassword, - ); - return true; - } - } - - return false; - }; - - const setPasswordFromTemporaryCode = app => async (tempCode, newpassword) => apiWrapper( - app, - events.authApi.setPasswordFromTemporaryCode, - alwaysAuthorized, - { tempCode, newpassword }, - _setPasswordFromTemporaryCode, app, tempCode, newpassword, - ); - - - const _setPasswordFromTemporaryCode = async (app, tempCode, newpassword) => { - const currentTime = await app.getEpochTime(); - - const temp = parseTemporaryCode(tempCode); - - const user = $(await _getUsers(app), [ - fp.find(u => u.temporaryAccessId === temp.id), - ]); - - if (!user) { return false; } - - const existingAuth = await app.datastore.loadJson( - userAuthFile(user.name), - ); - - if (isSomething(existingAuth.temporaryAccessHash) - && existingAuth.temporaryAccessExpiryEpoch > currentTime) { - const verified = await app.crypto.verify( - existingAuth.temporaryAccessHash, - temp.code, - ); - - if (verified) { - await doSet( - app, existingAuth, - user.name, newpassword, - ); - return true; - } - } - - return false; - }; - - const doSet = async (app, auth, username, newpassword) => { - auth.temporaryAccessHash = ''; - auth.temporaryAccessExpiryEpoch = 0; - auth.passwordHash = await app.crypto.hash( - newpassword, - ); - await app.datastore.updateJson( - userAuthFile(username), - auth, - ); - }; - - const scorePassword = app => password => apiWrapperSync( - app, - events.authApi.scorePassword, - alwaysAuthorized, - { password }, - _scorePassword, password, - ); - - const _scorePassword = (password) => { - // from https://stackoverflow.com/questions/948172/password-strength-meter - // thank you https://stackoverflow.com/users/46617/tm-lv - - let score = 0; - if (!password) { return score; } - - // award every unique letter until 5 repetitions - const letters = new Object(); - for (let i = 0; i < password.length; i++) { - letters[password[i]] = (letters[password[i]] || 0) + 1; - score += 5.0 / letters[password[i]]; - } - - // bonus points for mixing it up - const variations = { - digits: /\d/.test(password), - lower: /[a-z]/.test(password), - upper: /[A-Z]/.test(password), - nonWords: /\W/.test(password), - }; - - let variationCount = 0; - for (const check in variations) { - variationCount += (variations[check] == true) ? 1 : 0; - } - score += (variationCount - 1) * 10; - - const strengthText = score > 80 - ? 'strong' - : score > 60 - ? 'good' - : score >= 30 - ? 'weak' - : 'very weak'; - - return { - score: parseInt(score), - strengthText, - }; - }; - - const createUser$1 = app => async (user, password = null) => apiWrapper( - app, - events.authApi.createUser, - permission.createUser.isAuthorized, - { user, password }, - _createUser, app, user, password, - ); - - const _createUser = async (app, user, password = null) => { - const lock = await getLock( - app, USERS_LOCK_FILE, 1000, 2, - ); - - if (isNolock(lock)) { throw new Error('Unable to create user, could not get lock - try again'); } - - const users = await app.datastore.loadJson(USERS_LIST_FILE); - - const userErrors = validateUser()([...users, user], user); - if (userErrors.length > 0) { throw new BadRequestError(`User is invalid. ${fp.join('; ')(userErrors)}`); } - - const { auth, tempCode, temporaryAccessId } = await getAccess( - app, password, - ); - user.tempCode = tempCode; - user.temporaryAccessId = temporaryAccessId; - - if (fp.some(u => insensitiveEquals(u.name, user.name))(users)) { - throw new BadRequestError('User already exists'); - } - - users.push( - stripUserOfSensitiveStuff(user), - ); - - await app.datastore.updateJson( - USERS_LIST_FILE, - users, - ); - - try { - await app.datastore.createJson( - userAuthFile(user.name), - auth, - ); - } catch (_) { - await app.datastore.updateJson( - userAuthFile(user.name), - auth, - ); - } - - await releaseLock(app, lock); - - return user; - }; - - const getAccess = async (app, password) => { - const auth = getNewUserAuth(app)(); - - if (isNonEmptyString(password)) { - if (isValidPassword(password)) { - auth.passwordHash = await app.crypto.hash(password); - auth.temporaryAccessHash = ''; - auth.temporaryAccessId = ''; - auth.temporaryAccessExpiryEpoch = 0; - return { auth }; - } - throw new BadRequestError('Password does not meet requirements'); - } else { - const tempAccess = await getTemporaryCode(app); - auth.temporaryAccessHash = tempAccess.temporaryAccessHash; - auth.temporaryAccessExpiryEpoch = tempAccess.temporaryAccessExpiryEpoch; - auth.passwordHash = ''; - return ({ - auth, - tempCode: tempAccess.tempCode, - temporaryAccessId: tempAccess.temporaryAccessId, - }); - } - }; - - const enableUser = app => async username => apiWrapper( - app, - events.authApi.enableUser, - permission.enableDisableUser.isAuthorized, - { username }, - _enableUser, app, username, - ); - - const disableUser = app => async username => apiWrapper( - app, - events.authApi.disableUser, - permission.enableDisableUser.isAuthorized, - { username }, - _disableUser, app, username, - ); - - const _enableUser = async (app, username) => await toggleUser(app, username, true); - - const _disableUser = async (app, username) => await toggleUser(app, username, false); - - const toggleUser = async (app, username, enabled) => { - const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0); - - const actionName = enabled ? 'enable' : 'disable'; - - if (isNolock(lock)) { throw new Error(`Could not ${actionName} user - cannot get lock`); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - const user = getUserByName(users, username); - if (!user) { throw new NotFoundError(`Could not find user to ${actionName}`); } - - if (user.enabled === !enabled) { - user.enabled = enabled; - await app.datastore.updateJson(USERS_LIST_FILE, users); - } - } finally { - releaseLock(app, lock); - } - }; - - const getNewAccessLevel = () => () => ({ - name: '', - permissions: [], - default:false - }); - - const isAllowedType = t => $(permissionTypes, [ - fp.values, - fp.includes(t), - ]); - - const isRecordOrIndexType = t => fp.some(p => p === t)([ - permissionTypes.CREATE_RECORD, - permissionTypes.UPDATE_RECORD, - permissionTypes.DELETE_RECORD, - permissionTypes.READ_RECORD, - permissionTypes.READ_INDEX, - permissionTypes.EXECUTE_ACTION, - ]); - - - const permissionRules = app => ([ - makerule('type', 'type must be one of allowed types', - p => isAllowedType(p.type)), - makerule('nodeKey', 'record and index permissions must include a valid nodeKey', - p => (!isRecordOrIndexType(p.type)) - || isSomething(getNode(app.hierarchy, p.nodeKey))), - ]); - - const applyPermissionRules = app => applyRuleSet(permissionRules(app)); - - const accessLevelRules = allLevels => ([ - makerule('name', 'name must be set', - l => isNonEmptyString(l.name)), - makerule('name', 'access level names must be unique', - l => fp.isEmpty(l.name) - || fp.filter(a => insensitiveEquals(l.name, a.name))(allLevels).length === 1), - ]); - - const applyLevelRules = allLevels => applyRuleSet(accessLevelRules(allLevels)); - - const validateAccessLevel = app => (allLevels, level) => { - const errs = $(level.permissions, [ - fp.map(applyPermissionRules(app)), - fp.flatten, - fp.concat( - applyLevelRules(allLevels)(level), - ), - ]); - - return errs; - }; - - const validateAccessLevels = app => allLevels => apiWrapperSync( - app, - events.authApi.validateAccessLevels, - alwaysAuthorized, - { allLevels }, - _validateAccessLevels, app, allLevels, - ); - - const _validateAccessLevels = (app, allLevels) => $(allLevels, [ - fp.map(l => validateAccessLevel(app)(allLevels, l)), - fp.flatten, - fp.uniqWith((x, y) => x.field === y.field - && x.item === y.item - && x.error === y.error), - ]); - - const saveAccessLevels = app => async accessLevels => apiWrapper( - app, - events.authApi.saveAccessLevels, - permission.writeAccessLevels.isAuthorized, - { accessLevels }, - _saveAccessLevels, app, accessLevels, - ); - - const _saveAccessLevels = async (app, accessLevels) => { - const validationErrors = validateAccessLevels(app)(accessLevels.levels); - if (validationErrors.length > 0) { - const errs = $(validationErrors, [ - fp.map(e => e.error), - fp.join(', '), - ]); - throw new Error( - `Access Levels Invalid: ${errs}`, - ); - } - - const lock = await getLock( - app, ACCESS_LEVELS_LOCK_FILE, 2000, 2, - ); - - if (isNolock(lock)) { throw new Error('Could not get lock to save access levels'); } - - try { - const existing = await app.datastore.loadJson(ACCESS_LEVELS_FILE); - if (existing.version !== accessLevels.version) { throw new Error('Access levels have already been updated, since you loaded'); } - - accessLevels.version++; - - app.datastore.updateJson(ACCESS_LEVELS_FILE, accessLevels); - } finally { - await releaseLock(app, lock); - } - }; - - const generateFullPermissions = (app) => { - const allNodes = getFlattenedHierarchy(app.hierarchy); - const accessLevel = { permissions: [] }; - - const recordNodes = $(allNodes, [ - fp.filter(isRecord), - ]); - - for (const n of recordNodes) { - permission.createRecord.add(n.nodeKey(), accessLevel); - permission.updateRecord.add(n.nodeKey(), accessLevel); - permission.deleteRecord.add(n.nodeKey(), accessLevel); - permission.readRecord.add(n.nodeKey(), accessLevel); - } - - const indexNodes = $(allNodes, [ - fp.filter(isIndex), - ]); - - for (const n of indexNodes) { - permission.readIndex.add(n.nodeKey(), accessLevel); - } - - for (const a of fp.keys(app.actions)) { - permission.executeAction.add(a, accessLevel); - } - - $(permission, [ - fp.values, - fp.filter(p => !p.isNode), - fp.each(p => p.add(accessLevel)), - ]); - - return accessLevel.permissions; - }; - - const setUserAccessLevels$1 = app => async (userName, accessLevels) => apiWrapper( - app, - events.authApi.setUserAccessLevels, - permission.setUserAccessLevels.isAuthorized, - { userName, accessLevels }, - _setUserAccessLevels, app, userName, accessLevels, - ); - - const _setUserAccessLevels = async (app, username, accessLevels) => { - const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0); - - const actualAccessLevels = $( - await app.datastore.loadJson(ACCESS_LEVELS_FILE), - [ - l => l.levels, - fp.map(l => l.name), - ], - ); - - const missing = fp.difference(accessLevels)(actualAccessLevels); - if (missing.length > 0) { - throw new Error(`Invalid access levels supplied: ${fp.join(', ', missing)}`); - } - - if (isNolock(lock)) { throw new Error('Could set user access levels cannot get lock'); } - - try { - const users = await app.datastore.loadJson(USERS_LIST_FILE); - const user = getUserByName(users, username); - if (!user) { throw new NotFoundError(`Could not find user with ${username}`); } - - user.accessLevels = accessLevels; - await app.datastore.updateJson(USERS_LIST_FILE, users); - } finally { - releaseLock(app, lock); - } - }; - - const getAuthApi = app => ({ - authenticate: authenticate(app), - authenticateTemporaryAccess: authenticateTemporaryAccess(app), - createTemporaryAccess: createTemporaryAccess$1(app), - createUser: createUser$1(app), - loadAccessLevels: loadAccessLevels(app), - enableUser: enableUser(app), - disableUser: disableUser(app), - getNewAccessLevel: getNewAccessLevel(), - getNewUser: getNewUser(app), - getNewUserAuth: getNewUserAuth(app), - getUsers: getUsers(app), - saveAccessLevels: saveAccessLevels(app), - isAuthorized: isAuthorized(app), - changeMyPassword: changeMyPassword(app), - setPasswordFromTemporaryCode: setPasswordFromTemporaryCode(app), - scorePassword, - isValidPassword: isValidPassword(app), - validateUser: validateUser(), - validateAccessLevels: validateAccessLevels(app), - generateFullPermissions: () => generateFullPermissions(app), - setUserAccessLevels: setUserAccessLevels$1(app), - }); - - const executeAction$1 = app => (actionName, options) => { - apiWrapperSync( - app, - events.actionsApi.execute, - permission.executeAction.isAuthorized(actionName), - { actionName, options }, - app.actions[actionName], options, - ); - }; - - const _executeAction = (behaviourSources, action, options) => behaviourSources[action.behaviourSource][action.behaviourName](options); - - const getActionsApi = app => ({ - execute: executeAction$1(app), - }); - - const publish = handlers => async (eventName, context = {}) => { - if (!fp.has(eventName)(handlers)) return; - - for (const handler of handlers[eventName]) { - await handler(eventName, context); - } - }; - - const subscribe = handlers => (eventName, handler) => { - if (!fp.has(eventName)(handlers)) { - handlers[eventName] = []; - } - handlers[eventName].push(handler); - }; - - const createEventAggregator = () => { - const handlers = {}; - const eventAggregator = ({ - publish: publish(handlers), - subscribe: subscribe(handlers), - }); - return eventAggregator; - }; - - const createJson = originalCreateFile => async (key, obj, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, key, JSON.stringify(obj)); - - const createNewFile = originalCreateFile => async (path, content, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, path, content); - - const loadJson = datastore => async (key, retries = 3, delay = 100) => { - try { - return await retry(JSON.parse, retries, delay, await datastore.loadFile(key)); - } catch (err) { - const newErr = new NotFoundError(err.message); - newErr.stack = err.stack; - throw(newErr); - } - }; - - const updateJson = datastore => async (key, obj, retries = 3, delay = 100) => { - try { - return await retry(datastore.updateFile, retries, delay, key, JSON.stringify(obj)); - } catch (err) { - const newErr = new NotFoundError(err.message); - newErr.stack = err.stack; - throw(newErr); - } - }; - - const setupDatastore = (datastore) => { - const originalCreateFile = datastore.createFile; - datastore.loadJson = loadJson(datastore); - datastore.createJson = createJson(originalCreateFile); - datastore.updateJson = updateJson(datastore); - datastore.createFile = createNewFile(originalCreateFile); - if (datastore.createEmptyDb) { delete datastore.createEmptyDb; } - return datastore; - }; - - const compileCode = code => { - let func; - - try { - func = compilerUtil.compileCode(code); - } catch(e) { - e.message = `Error compiling code : ${code} : ${e.message}`; - throw e; - } - - return func; - }; - - const compileExpression = code => { - let func; - - try { - func = compilerUtil.compileExpression(code); - } catch(e) { - e.message = `Error compiling expression : ${code} : ${e.message}`; - throw e; - } - - return func; - }; - - const initialiseActions = (subscribe, behaviourSources, actions, triggers, apis) => { - validateSources(behaviourSources, actions); - subscribeTriggers(subscribe, behaviourSources, actions, triggers, apis); - return createActionsCollection(behaviourSources, actions); - }; - - const createActionsCollection = (behaviourSources, actions) => $(actions, [ - fp.reduce((all, a) => { - all[a.name] = opts => _executeAction(behaviourSources, a, opts); - return all; - }, {}), - ]); - - const subscribeTriggers = (subscribe, behaviourSources, actions, triggers, apis) => { - const createOptions = (optionsCreator, eventContext) => { - if (!optionsCreator) return {}; - const create = compileCode(optionsCreator); - return create({ context: eventContext, apis }); - }; - - const shouldRunTrigger = (trigger, eventContext) => { - if (!trigger.condition) return true; - const shouldRun = compileExpression(trigger.condition); - return shouldRun({ context: eventContext }); - }; - - for (let trig of triggers) { - subscribe(trig.eventName, async (ev, ctx) => { - if (shouldRunTrigger(trig, ctx)) { - await _executeAction( - behaviourSources, - fp.find(a => a.name === trig.actionName)(actions), - createOptions(trig.optionsCreator, ctx), - ); - } - }); - } - }; - - const validateSources = (behaviourSources, actions) => { - const declaredSources = $(actions, [ - fp.uniqBy(a => a.behaviourSource), - fp.map(a => a.behaviourSource), - ]); - - const suppliedSources = fp.keys(behaviourSources); - - const missingSources = fp.difference( - declaredSources, suppliedSources, - ); - - if (missingSources.length > 0) { - throw new BadRequestError(`Declared behaviour sources are not supplied: ${fp.join(', ', missingSources)}`); - } - - const missingBehaviours = $(actions, [ - fp.filter(a => !fp.isFunction(behaviourSources[a.behaviourSource][a.behaviourName])), - fp.map(a => `Action: ${a.name} : ${a.behaviourSource}.${a.behaviourName}`), - ]); - - if (missingBehaviours.length > 0) { - throw new NotFoundError(`Missing behaviours: could not find behaviour functions: ${fp.join(', ', missingBehaviours)}`); - } - }; - - const retrieve = async (app) => { - const transactionFiles = await app.datastore.getFolderContents( - TRANSACTIONS_FOLDER, - ); - - let transactions = []; - - if (fp.some(isBuildIndexFolder)(transactionFiles)) { - const buildIndexFolder = fp.find(isBuildIndexFolder)(transactionFiles); - - transactions = await retrieveBuildIndexTransactions( - app, - joinKey(TRANSACTIONS_FOLDER, buildIndexFolder), - ); - } - - if (transactions.length > 0) return transactions; - - return await retrieveStandardTransactions( - app, transactionFiles, - ); - }; - - const retrieveBuildIndexTransactions = async (app, buildIndexFolder) => { - const childFolders = await app.datastore.getFolderContents(buildIndexFolder); - if (childFolders.length === 0) { - // cleanup - await app.datastore.deleteFolder(buildIndexFolder); - return []; - } - - const getTransactionFiles = async (childFolderIndex = 0) => { - if (childFolderIndex >= childFolders.length) return []; - - const childFolderKey = joinKey(buildIndexFolder, childFolders[childFolderIndex]); - const files = await app.datastore.getFolderContents( - childFolderKey, - ); - - if (files.length === 0) { - await app.datastore.deleteFolder(childFolderKey); - return await getTransactionFiles(childFolderIndex + 1); - } - - return { childFolderKey, files }; - }; - - const transactionFiles = await getTransactionFiles(); - - if (transactionFiles.files.length === 0) return []; - - const transactions = $(transactionFiles.files, [ - fp.map(parseTransactionId), - ]); - - for (const t of transactions) { - const transactionContent = await app.datastore.loadJson( - joinKey( - transactionFiles.childFolderKey, - t.fullId, - ), - ); - t.record = await _load(app, transactionContent.recordKey); - } - - transactions.indexNode = $(buildIndexFolder, [ - getLastPartInKey, - nodeKeyHashFromBuildFolder, - getNodeFromNodeKeyHash(app.hierarchy), - ]); - - transactions.folderKey = transactionFiles.childFolderKey; - - return transactions; - }; - - const retrieveStandardTransactions = async (app, transactionFiles) => { - const transactionIds = $(transactionFiles, [ - fp.filter(f => f !== LOCK_FILENAME - && !isBuildIndexFolder(f)), - fp.map(parseTransactionId), - ]); - - const transactionIdsByRecord = $(transactionIds, [ - fp.groupBy('recordId'), - ]); - - const dedupedTransactions = []; - - const verify = async (t) => { - if (t.verified === true) return t; - - const id = getTransactionId( - t.recordId, - t.transactionType, - t.uniqueId, - ); - - const transaction = await app.datastore.loadJson( - joinKey(TRANSACTIONS_FOLDER, id), - ); - - if (isDelete(t)) { - t.record = transaction.record; - t.verified = true; - return t; - } - - const rec = await _load( - app, - transaction.recordKey, - ); - if (rec.transactionId === id) { - t.record = rec; - if (transaction.oldRecord) { t.oldRecord = transaction.oldRecord; } - t.verified = true; - } else { - t.verified = false; - } - - return t; - }; - - const pickOne = async (trans, forType) => { - const transForType = fp.filter(forType)(trans); - if (transForType.length === 1) { - const t = await verify(transForType[0]); - return (t.verified === true ? t : null); - } - for (let t of transForType) { - t = await verify(t); - if (t.verified === true) { return t; } - } - - return null; - }; - - for (const recordId in transactionIdsByRecord) { - const transIdsForRecord = transactionIdsByRecord[recordId]; - if (transIdsForRecord.length === 1) { - const t = await verify(transIdsForRecord[0]); - if (t.verified) { dedupedTransactions.push(t); } - continue; - } - if (fp.some(isDelete)(transIdsForRecord)) { - const t = await verify(fp.find(isDelete)(transIdsForRecord)); - if (t.verified) { dedupedTransactions.push(t); } - continue; - } - if (fp.some(isUpdate)(transIdsForRecord)) { - const upd = await pickOne(transIdsForRecord, isUpdate); - if (isSomething(upd) && upd.verified) { dedupedTransactions.push(upd); } - continue; - } - if (fp.some(isCreate)(transIdsForRecord)) { - const cre = await pickOne(transIdsForRecord, isCreate); - if (isSomething(cre)) { dedupedTransactions.push(cre); } - continue; - } - } - - const duplicates = $(transactionIds, [ - fp.filter(t => none(ddt => ddt.uniqueId === t.uniqueId)(dedupedTransactions)), - ]); - - - const deletePromises = fp.map(t => app.datastore.deleteFile( - joinKey( - TRANSACTIONS_FOLDER, - getTransactionId( - t.recordId, - t.transactionType, - t.uniqueId, - ), - ), - ))(duplicates); - - await Promise.all(deletePromises); - - return dedupedTransactions; - }; - - const parseTransactionId = (id) => { - const splitId = fp.split(idSep)(id); - return ({ - recordId: splitId[0], - transactionType: splitId[1], - uniqueId: splitId[2], - fullId: id, - }); - }; - - const getRelevantAncestorIndexes = (hierarchy, record) => { - const key = record.key; - const keyParts = splitKey(key); - const nodeId = getRecordNodeId(key); - - const flatHierarchy = _.orderBy(getFlattenedHierarchy(hierarchy), - [node => node.pathRegx().length], - ['desc']); - - const makeindexNodeAndDir_ForAncestorIndex = (indexNode, parentRecordDir) => makeIndexNodeAndDir(indexNode, joinKey(parentRecordDir, indexNode.name)); - - const traverseAncestorIndexesInPath = () => fp.reduce((acc, part) => { - const currentIndexKey = joinKey(acc.lastIndexKey, part); - acc.lastIndexKey = currentIndexKey; - const testPathRegx = p => new RegExp(`${p.pathRegx()}$`).test(currentIndexKey); - const nodeMatch = fp.find(testPathRegx)(flatHierarchy); - - if (isNothing(nodeMatch)) { return acc; } - - if (!isRecord(nodeMatch) - || nodeMatch.indexes.length === 0) { return acc; } - - const indexes = $(nodeMatch.indexes, [ - fp.filter(i => i.indexType === indexTypes.ancestor - && (i.allowedRecordNodeIds.length === 0 - || fp.includes(nodeId)(i.allowedRecordNodeIds))), - ]); - - const currentRecordDir = getRecordInfo(hierarchy, currentIndexKey).dir; - - fp.each(v => acc.nodesAndKeys.push( - makeindexNodeAndDir_ForAncestorIndex(v, currentRecordDir), - ))(indexes); - - return acc; - }, { lastIndexKey: '', nodesAndKeys: [] })(keyParts).nodesAndKeys; - - const rootIndexes = $(flatHierarchy, [ - fp.filter(n => isGlobalIndex(n) && recordNodeIdIsAllowed(n)(nodeId)), - fp.map(i => makeIndexNodeAndDir( - i, - getIndexDir(hierarchy, i.nodeKey()))), - ]); - - return fp.union(traverseAncestorIndexesInPath())(rootIndexes); - }; - - const getRelevantReverseReferenceIndexes = (hierarchy, record) => $(record.key, [ - getExactNodeForKey(hierarchy), - n => n.fields, - fp.filter(f => f.type === 'reference' - && isSomething(record[f.name]) - && isNonEmptyString(record[f.name].key)), - fp.map(f => $(f.typeOptions.reverseIndexNodeKeys, [ - fp.map(n => ({ - recordNode: getNode(hierarchy, n), - field: f, - })), - ])), - fp.flatten, - fp.map(n => makeIndexNodeAndDir( - n.recordNode, - joinKey( - getRecordInfo(hierarchy, record[n.field.name].key).dir, - n.recordNode.name), - )), - ]); - - const makeIndexNodeAndDir = (indexNode, indexDir) => ({ indexNode, indexDir }); - - // adapted from https://github.com/dex4er/js-promise-writable - // Thank you :) - const promiseWriteableStream = stream => { - - let _errored; - - const _errorHandler = err => { - _errored = err; - }; - - stream.on("error", _errorHandler); - - const write = chunk => { - let rejected = false; - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err); - } - - if (!stream.writable || stream.closed || stream.destroyed) { - return reject(new Error("write after end")); - } - - const writeErrorHandler = err => { - _errored = undefined; - rejected = true; - reject(err); - }; - - stream.once("error", writeErrorHandler); - - const canWrite = stream.write(chunk); - - stream.removeListener("error", writeErrorHandler); - - if (canWrite) { - if (!rejected) { - resolve(chunk.length); - } - } else { - const errorHandler = err => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const drainHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const closeHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const finishHandler = () => { - removeListeners(); - resolve(chunk.length); - }; - - const removeListeners = () => { - stream.removeListener("close", closeHandler); - stream.removeListener("drain", drainHandler); - stream.removeListener("error", errorHandler); - stream.removeListener("finish", finishHandler); - }; - - stream.on("close", closeHandler); - stream.on("drain", drainHandler); - stream.on("error", errorHandler); - stream.on("finish", finishHandler); - } - }) - }; - - const end = () => { - - return new Promise((resolve, reject) => { - if (_errored) { - const err = _errored; - _errored = undefined; - return reject(err); - } - - if (!stream.writable || stream.closed || stream.destroyed) { - return resolve(); - } - - const finishHandler = () => { - removeListeners(); - resolve(); - }; - - const errorHandler = (err) => { - _errored = undefined; - removeListeners(); - reject(err); - }; - - const removeListeners = () => { - stream.removeListener("error", errorHandler); - stream.removeListener("finish", finishHandler); - }; - - stream.on("finish", finishHandler); - stream.on("error", errorHandler); - - stream.end(); - }) - }; - - return {write, end}; - }; - - const applyToShard = async (hierarchy, store, indexDir, - indexNode, indexShardKey, recordsToWrite, keysToRemove) => { - const createIfNotExists = recordsToWrite.length > 0; - const writer = await getWriter(hierarchy, store, indexDir, indexShardKey, indexNode, createIfNotExists); - if (writer === SHARD_DELETED) return; - - await writer.updateIndex(recordsToWrite, keysToRemove); - await swapTempFileIn(store, indexShardKey); - }; - - const SHARD_DELETED = 'SHARD_DELETED'; - const getWriter = async (hierarchy, store, indexDir, indexedDataKey, indexNode, createIfNotExists) => { - let readableStream = null; - - if (isShardedIndex(indexNode)) { - await ensureShardNameIsInShardMap(store, indexDir, indexedDataKey); - if(!await store.exists(indexedDataKey)) { - if (await store.exists(getParentKey(indexedDataKey))) { - await store.createFile(indexedDataKey, ""); - } else { - return SHARD_DELETED; - } - } - } - - try { - - readableStream = promiseReadableStream( - await store.readableFileStream(indexedDataKey) - ); - - } catch (e) { - - if (await store.exists(indexedDataKey)) { - throw e; - } else { - if (createIfNotExists) { - if(await store.exists(getParentKey(indexedDataKey))) { - await store.createFile(indexedDataKey, ''); - } else { - return SHARD_DELETED; - } - } else { - return SHARD_DELETED; - } - - readableStream = promiseReadableStream( - await store.readableFileStream(indexedDataKey) - ); - - } - } - - const writableStream = promiseWriteableStream( - await store.writableFileStream(indexedDataKey + ".temp") - ); - - return getIndexWriter( - hierarchy, indexNode, - readableStream, writableStream - ); - }; - - const swapTempFileIn = async (store, indexedDataKey, isRetry = false) => { - const tempFile = `${indexedDataKey}.temp`; - try { - await store.deleteFile(indexedDataKey); - } catch (e) { - // ignore failure, incase it has not been created yet - - // if parent folder does not exist, assume that this index - // should not be there - if(!await store.exists(getParentKey(indexedDataKey))) { - return; - } - } - try { - await store.renameFile(tempFile, indexedDataKey); - } catch (e) { - // retrying in case delete failure was for some other reason - if (!isRetry) { - await swapTempFileIn(store, indexedDataKey, true); - } else { - throw new Error("Failed to swap in index filed: " + e.message); - } - } - }; - - const executeTransactions = app => async (transactions) => { - const recordsByShard = mappedRecordsByIndexShard(app.hierarchy, transactions); - - for (const shard of fp.keys(recordsByShard)) { - await applyToShard( - app.hierarchy, app.datastore, - recordsByShard[shard].indexDir, - recordsByShard[shard].indexNode, - shard, - recordsByShard[shard].writes, - recordsByShard[shard].removes, - ); - } - }; - - const mappedRecordsByIndexShard = (hierarchy, transactions) => { - const updates = getUpdateTransactionsByShard( - hierarchy, transactions, - ); - - const created = getCreateTransactionsByShard( - hierarchy, transactions, - ); - const deletes = getDeleteTransactionsByShard( - hierarchy, transactions, - ); - - const indexBuild = getBuildIndexTransactionsByShard( - hierarchy, - transactions, - ); - - const toRemove = [ - ...deletes, - ...updates.toRemove, - ]; - - const toWrite = [ - ...created, - ...updates.toWrite, - ...indexBuild, - ]; - - const transByShard = {}; - - const initialiseShard = (t) => { - if (fp.isUndefined(transByShard[t.indexShardKey])) { - transByShard[t.indexShardKey] = { - writes: [], - removes: [], - indexDir: t.indexDir, - indexNodeKey: t.indexNode.nodeKey(), - indexNode: t.indexNode, - }; - } - }; - - for (const trans of toWrite) { - initialiseShard(trans); - transByShard[trans.indexShardKey].writes.push( - trans.mappedRecord.result, - ); - } - - for (const trans of toRemove) { - initialiseShard(trans); - transByShard[trans.indexShardKey].removes.push( - trans.mappedRecord.result.key, - ); - } - - return transByShard; - }; - - const getUpdateTransactionsByShard = (hierarchy, transactions) => { - const updateTransactions = $(transactions, [fp.filter(isUpdate)]); - - const evaluateIndex = (record, indexNodeAndPath) => { - const mappedRecord = evaluate(record)(indexNodeAndPath.indexNode); - return ({ - mappedRecord, - indexNode: indexNodeAndPath.indexNode, - indexDir: indexNodeAndPath.indexDir, - indexShardKey: getIndexedDataKey( - indexNodeAndPath.indexNode, - indexNodeAndPath.indexDir, - mappedRecord.result, - ), - }); - }; - - const getIndexNodesToApply = indexFilter => (t, indexes) => $(indexes, [ - fp.map(n => ({ - old: evaluateIndex(t.oldRecord, n), - new: evaluateIndex(t.record, n), - })), - fp.filter(indexFilter), - ]); - - const toRemoveFilter = (n, isUnreferenced) => n.old.mappedRecord.passedFilter === true - && (n.new.mappedRecord.passedFilter === false - || isUnreferenced); - - const toAddFilter = (n, isNewlyReferenced) => (n.old.mappedRecord.passedFilter === false - || isNewlyReferenced) - && n.new.mappedRecord.passedFilter === true; - - const toUpdateFilter = n => n.new.mappedRecord.passedFilter === true - && n.old.mappedRecord.passedFilter === true - && !fp.isEqual(n.old.mappedRecord.result, - n.new.mappedRecord.result); - - const toRemove = []; - const toWrite = []; - - for (const t of updateTransactions) { - const ancestorIdxs = getRelevantAncestorIndexes( - hierarchy, t.record, - ); - - const referenceChanges = diffReverseRefForUpdate( - hierarchy, t.oldRecord, t.record, - ); - - // old records to remove (filtered out) - const filteredOut_toRemove = _.union( - getIndexNodesToApply(toRemoveFilter)(t, ancestorIdxs), - // still referenced - check filter - getIndexNodesToApply(toRemoveFilter)(t, referenceChanges.notChanged), - // un referenced - remove if in there already - getIndexNodesToApply(n => toRemoveFilter(n, true))(t, referenceChanges.unReferenced), - ); - - // new records to add (filtered in) - const filteredIn_toAdd = _.union( - getIndexNodesToApply(toAddFilter)(t, ancestorIdxs), - // newly referenced - check filter - getIndexNodesToApply(n => toAddFilter(n, true))(t, referenceChanges.newlyReferenced), - // reference unchanged - rerun filter in case something else changed - getIndexNodesToApply(toAddFilter)(t, referenceChanges.notChanged), - ); - - const changed = _.union( - getIndexNodesToApply(toUpdateFilter)(t, ancestorIdxs), - // still referenced - recheck filter - getIndexNodesToApply(toUpdateFilter)(t, referenceChanges.notChanged), - ); - - const shardKeyChanged = $(changed, [ - fp.filter(c => c.old.indexShardKey !== c.new.indexShardKey), - ]); - - const changedInSameShard = $(shardKeyChanged, [ - fp.difference(changed), - ]); - - for (const res of shardKeyChanged) { - fp.pull(res)(changed); - filteredOut_toRemove.push(res); - filteredIn_toAdd.push(res); - } - - toRemove.push( - $(filteredOut_toRemove, [ - fp.map(i => i.old), - ]), - ); - - toWrite.push( - $(filteredIn_toAdd, [ - fp.map(i => i.new), - ]), - ); - - toWrite.push( - $(changedInSameShard, [ - fp.map(i => i.new), - ]), - ); - } - - return ({ - toRemove: fp.flatten(toRemove), - toWrite: fp.flatten(toWrite), - }); - }; - - const getBuildIndexTransactionsByShard = (hierarchy, transactions) => { - const buildTransactions = $(transactions, [fp.filter(isBuildIndex)]); - if (!isNonEmptyArray(buildTransactions)) return []; - const indexNode = transactions.indexNode; - - const getIndexDirs = (t) => { - if (isGlobalIndex(indexNode)) { - return [indexNode.nodeKey()]; - } - - if (isReferenceIndex(indexNode)) { - const recordNode = getExactNodeForKey(hierarchy)(t.record.key); - const refFields = $(recordNode.fields, [ - fp.filter(fieldReversesReferenceToIndex(indexNode)), - ]); - const indexDirs = []; - for (const refField of refFields) { - const refValue = t.record[refField.name]; - if (isSomething(refValue) - && isNonEmptyString(refValue.key)) { - const indexDir = joinKey( - getRecordInfo(hierarchy, refValue.key).dir, - indexNode.name, - ); - - if (!fp.includes(indexDir)(indexDirs)) { indexDirs.push(indexDir); } - } - } - return indexDirs; - } - - const indexKey = joinKey( - getActualKeyOfParent( - indexNode.parent().nodeKey(), - t.record.key, - ), - indexNode.name, - ); - - return [getIndexDir(hierarchy, indexKey)]; - }; - - return $(buildTransactions, [ - fp.map((t) => { - const mappedRecord = evaluate(t.record)(indexNode); - if (!mappedRecord.passedFilter) return null; - const indexDirs = getIndexDirs(t); - return $(indexDirs, [ - fp.map(indexDir => ({ - mappedRecord, - indexNode, - indexDir, - indexShardKey: getIndexedDataKey( - indexNode, - indexDir, - mappedRecord.result, - ), - })), - ]); - }), - fp.flatten, - fp.filter(isSomething), - ]); - }; - - const get_Create_Delete_TransactionsByShard = pred => (hierarchy, transactions) => { - const createTransactions = $(transactions, [fp.filter(pred)]); - - const getIndexNodesToApply = (t, indexes) => $(indexes, [ - fp.map((n) => { - const mappedRecord = evaluate(t.record)(n.indexNode); - return ({ - mappedRecord, - indexNode: n.indexNode, - indexDir: n.indexDir, - indexShardKey: getIndexedDataKey( - n.indexNode, - n.indexDir, - mappedRecord.result, - ), - }); - }), - fp.filter(n => n.mappedRecord.passedFilter), - ]); - - const allToApply = []; - - for (const t of createTransactions) { - const ancestorIdxs = getRelevantAncestorIndexes(hierarchy, t.record); - const reverseRef = getRelevantReverseReferenceIndexes(hierarchy, t.record); - - allToApply.push( - getIndexNodesToApply(t, ancestorIdxs), - ); - allToApply.push( - getIndexNodesToApply(t, reverseRef), - ); - } - - return fp.flatten(allToApply); - }; - - const getDeleteTransactionsByShard = get_Create_Delete_TransactionsByShard(isDelete); - - const getCreateTransactionsByShard = get_Create_Delete_TransactionsByShard(isCreate); - - const diffReverseRefForUpdate = (appHierarchy, oldRecord, newRecord) => { - const oldIndexes = getRelevantReverseReferenceIndexes( - appHierarchy, oldRecord, - ); - const newIndexes = getRelevantReverseReferenceIndexes( - appHierarchy, newRecord, - ); - - const unReferenced = fp.differenceBy( - i => i.indexDir, - oldIndexes, newIndexes, - ); - - const newlyReferenced = fp.differenceBy( - i => i.indexDir, - newIndexes, oldIndexes, - ); - - const notChanged = fp.intersectionBy( - i => i.indexDir, - newIndexes, oldIndexes, - ); - - return { - unReferenced, - newlyReferenced, - notChanged, - }; - }; - - const cleanup = async (app) => { - const lock = await getTransactionLock(app); - if (isNolock(lock)) return; - - try { - const transactions = await retrieve(app); - if (transactions.length > 0) { - await executeTransactions(app)(transactions); - - const folder = transactions.folderKey - ? transactions.folderKey - : TRANSACTIONS_FOLDER; - - const deleteFiles = $(transactions, [ - fp.map(t => joinKey( - folder, - getTransactionId( - t.recordId, t.transactionType, - t.uniqueId, - ), - )), - fp.map(app.datastore.deleteFile), - ]); - - await Promise.all(deleteFiles); - } - } finally { - await releaseLock(app, lock); - } - }; - - const getTransactionLock = async app => await getLock( - app, LOCK_FILE_KEY, - timeoutMilliseconds, maxLockRetries, - ); - - const initialiseData = async (datastore, applicationDefinition, accessLevels) => { - await datastore.createFolder(configFolder); - await datastore.createJson(appDefinitionFile, applicationDefinition); - - await initialiseRootCollections(datastore, applicationDefinition.hierarchy); - await initialiseRootIndexes(datastore, applicationDefinition.hierarchy); - - await datastore.createFolder(TRANSACTIONS_FOLDER); - - await datastore.createFolder(AUTH_FOLDER); - - await datastore.createJson(USERS_LIST_FILE, []); - - await datastore.createJson( - ACCESS_LEVELS_FILE, - accessLevels ? accessLevels : { version: 0, levels: [] }); - - await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy); - }; - - const initialiseRootIndexes = async (datastore, hierarchy) => { - const flathierarchy = getFlattenedHierarchy(hierarchy); - const globalIndexes = $(flathierarchy, [ - fp.filter(isGlobalIndex), - ]); - - for (const index of globalIndexes) { - if (!await datastore.exists(index.nodeKey())) { - await initialiseIndex(datastore, '', index); - } - } - }; - - const initialiseRootSingleRecords = async (datastore, hierarchy) => { - const app = { - publish:()=>{}, - cleanupTransactions: () => {}, - datastore, hierarchy - }; - - const flathierarchy = getFlattenedHierarchy(hierarchy); - const singleRecords = $(flathierarchy, [ - fp.filter(isSingleRecord), - ]); - - for (let record of singleRecords) { - await datastore.createFolder(record.nodeKey()); - const result = _getNew(record, ""); - await _save(app,result); - } - }; - - const getDatabaseManager = databaseManager => ({ - createEmptyMasterDb: createEmptyMasterDb(databaseManager), - createEmptyInstanceDb: createEmptyInstanceDb(databaseManager), - getInstanceDbRootConfig: databaseManager.getInstanceDbRootConfig, - masterDatastoreConfig: getMasterDatastoreConfig(databaseManager), - getInstanceDatastoreConfig: getInstanceDatastoreConfig(databaseManager), - }); - - const getMasterDatastoreConfig = databaseManager => databaseManager.getDatastoreConfig('master'); - - const getInstanceDatastoreConfig = databaseManager => (applicationId, instanceId) => databaseManager.getDatastoreConfig( - applicationId, instanceId, - ); - - const createEmptyMasterDb = databaseManager => async () => await databaseManager.createEmptyDb('master'); - - const createEmptyInstanceDb = databaseManager => async (applicationId, instanceId) => { - if (isNothing(applicationId)) { throw new Error('CreateDb: application id not supplied'); } - if (isNothing(instanceId)) { throw new Error('CreateDb: instance id not supplied'); } - - return await databaseManager.createEmptyDb( - applicationId, - instanceId, - ); - }; - - const getAppApis = async (store, behaviourSources = null, - cleanupTransactions = null, - getEpochTime = null, - crypto = null, - appDefinition = null) => { - - store = setupDatastore(store); - - if(!appDefinition) - appDefinition = await getApplicationDefinition(store)(); - - if(!behaviourSources) - behaviourSources = await getBehaviourSources(store); - - const eventAggregator = createEventAggregator(); - - const app = { - datastore:store, - crypto, - publish:eventAggregator.publish, - hierarchy:appDefinition.hierarchy, - actions:appDefinition.actions - }; - - const templateApi = getTemplateApi(app); - - app.cleanupTransactions = isSomething(cleanupTransactions) - ? cleanupTransactions - : async () => await cleanup(app); - - app.getEpochTime = isSomething(getEpochTime) - ? getEpochTime - : async () => (new Date()).getTime(); - - const recordApi = getRecordApi(app); - const collectionApi = getCollectionApi(app); - const indexApi = getIndexApi(app); - const authApi = getAuthApi(app); - const actionsApi = getActionsApi(app); - - const authenticateAs = async (username, password) => { - app.user = await authApi.authenticate(username, password); - }; - - const withFullAccess = () => - userWithFullAccess(app); - - const asUser = (user) => { - app.user = user; - }; - - let apis = { - recordApi, - templateApi, - collectionApi, - indexApi, - authApi, - actionsApi, - subscribe: eventAggregator.subscribe, - authenticateAs, - withFullAccess, - asUser - }; - - apis.actions = initialiseActions( - eventAggregator.subscribe, - behaviourSources, - appDefinition.actions, - appDefinition.triggers, - apis); - - - return apis; - }; - - const userWithFullAccess = (app) => { - app.user = { - name: "app", - permissions : generateFullPermissions(app), - isUser:false, - temp:false - }; - return app.user; - }; - - exports.common = index; - exports.default = getAppApis; - exports.events = events; - exports.eventsList = eventsList; - exports.getActionsApi = getActionsApi; - exports.getAppApis = getAppApis; - exports.getAuthApi = getAuthApi; - exports.getCollectionApi = getCollectionApi; - exports.getDatabaseManager = getDatabaseManager; - exports.getIndexApi = getIndexApi; - exports.getRecordApi = getRecordApi; - exports.getTemplateApi = getTemplateApi; - exports.hierarchy = hierarchy; - exports.initialiseData = initialiseData; - exports.setupDatastore = setupDatastore; - exports.userWithFullAccess = userWithFullAccess; - - Object.defineProperty(exports, '__esModule', { value: true }); - -})); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"budibase-core.umd.js","sources":["../src/common/events.js","../src/common/errors.js","../src/common/apiWrapper.js","../src/common/lock.js","../src/common/index.js","../src/common/validationCommon.js","../src/indexing/evaluate.js","../src/templateApi/indexes.js","../src/templateApi/hierarchy.js","../src/types/typeHelpers.js","../src/types/string.js","../src/types/bool.js","../src/types/number.js","../src/types/datetime.js","../src/types/array.js","../src/types/reference.js","../src/types/file.js","../src/types/index.js","../src/authApi/authCommon.js","../src/authApi/isAuthorized.js","../src/authApi/permissions.js","../src/recordApi/getNew.js","../src/indexing/allIds.js","../src/recordApi/recordInfo.js","../src/recordApi/load.js","../src/indexing/promiseReadableStream.js","../src/indexing/sharding.js","../src/indexing/indexSchemaCreator.js","../node_modules/rollup-plugin-node-globals/src/global.js","../node_modules/buffer-es6/base64.js","../node_modules/buffer-es6/ieee754.js","../node_modules/buffer-es6/isArray.js","../node_modules/buffer-es6/index.js","../node_modules/rollup-plugin-node-builtins/src/es6/string-decoder.js","../src/indexing/serializer.js","../src/indexing/read.js","../src/indexApi/getIndexDir.js","../src/indexApi/listItems.js","../src/recordApi/getContext.js","../src/recordApi/validate.js","../src/collectionApi/initialise.js","../src/transactions/transactionsCommon.js","../src/transactions/create.js","../src/indexing/initialiseIndex.js","../src/recordApi/save.js","../src/collectionApi/delete.js","../src/recordApi/delete.js","../src/recordApi/uploadFile.js","../src/recordApi/downloadFile.js","../src/recordApi/customId.js","../src/recordApi/index.js","../src/collectionApi/getAllowedRecordTypes.js","../src/collectionApi/index.js","../src/indexApi/buildIndex.js","../src/indexApi/aggregates.js","../src/indexApi/index.js","../src/templateApi/createNodes.js","../src/templateApi/fields.js","../src/templateApi/recordValidationRules.js","../src/templateApi/createActions.js","../src/templateApi/validateAggregate.js","../src/templateApi/validate.js","../src/templateApi/getApplicationDefinition.js","../src/templateApi/saveApplicationHierarchy.js","../src/templateApi/saveActionsAndTriggers.js","../src/templateApi/getBehaviourSources.js","../src/templateApi/index.js","../src/authApi/getUsers.js","../src/authApi/loadAccessLevels.js","../src/authApi/authenticate.js","../src/authApi/createTemporaryAccess.js","../src/authApi/validateUser.js","../src/authApi/getNewUser.js","../src/authApi/setPassword.js","../src/authApi/createUser.js","../src/authApi/enableUser.js","../src/authApi/getNewAccessLevel.js","../src/authApi/validateAccessLevels.js","../src/authApi/saveAccessLevels.js","../src/authApi/generateFullPermissions.js","../src/authApi/setUserAccessLevels.js","../src/authApi/index.js","../src/actionsApi/execute.js","../src/actionsApi/index.js","../src/appInitialise/eventAggregator.js","../src/appInitialise/index.js","../src/common/compileCode.js","../src/actionsApi/initialise.js","../src/transactions/retrieve.js","../src/indexing/relevant.js","../src/indexing/promiseWritableStream.js","../src/indexing/apply.js","../src/transactions/execute.js","../src/transactions/cleanup.js","../src/appInitialise/initialiseData.js","../src/appInitialise/databaseManager.js","../src/index.js"],"sourcesContent":["import { union, reduce } from 'lodash/fp';\n\nconst commonPlus = extra => union(['onBegin', 'onComplete', 'onError'])(extra);\n\nconst common = () => commonPlus([]);\n\nconst _events = {\n  recordApi: {\n    save: commonPlus([\n      'onInvalid',\n      'onRecordUpdated',\n      'onRecordCreated']),\n    delete: common(),\n    getContext: common(),\n    getNew: common(),\n    load: common(),\n    validate: common(),\n    uploadFile: common(),\n    downloadFile: common(),\n  },\n  indexApi: {\n    buildIndex: common(),\n    listItems: common(),\n    delete: common(),\n    aggregates: common(),\n  },\n  collectionApi: {\n    getAllowedRecordTypes: common(),\n    initialise: common(),\n    delete: common(),\n  },\n  authApi: {\n    authenticate: common(),\n    authenticateTemporaryAccess: common(),\n    createTemporaryAccess: common(),\n    createUser: common(),\n    enableUser: common(),\n    disableUser: common(),\n    loadAccessLevels: common(),\n    getNewAccessLevel: common(),\n    getNewUser: common(),\n    getNewUserAuth: common(),\n    getUsers: common(),\n    saveAccessLevels: common(),\n    isAuthorized: common(),\n    changeMyPassword: common(),\n    setPasswordFromTemporaryCode: common(),\n    scorePassword: common(),\n    isValidPassword: common(),\n    validateUser: common(),\n    validateAccessLevels: common(),\n    setUserAccessLevels: common(),\n  },\n  templateApi: {\n    saveApplicationHierarchy: common(),\n    saveActionsAndTriggers: common(),\n  },\n  actionsApi: {\n    execute: common(),\n  },\n};\n\nconst _eventsList = [];\n\nconst makeEvent = (area, method, name) => `${area}:${method}:${name}`;\n\nfor (const areaKey in _events) {\n  for (const methodKey in _events[areaKey]) {\n    _events[areaKey][methodKey] = reduce((obj, s) => {\n      obj[s] = makeEvent(areaKey, methodKey, s);\n      return obj;\n    },\n    {})(_events[areaKey][methodKey]);\n  }\n}\n\n\nfor (const areaKey in _events) {\n  for (const methodKey in _events[areaKey]) {\n    for (const name in _events[areaKey][methodKey]) {\n      _eventsList.push(\n        _events[areaKey][methodKey][name],\n      );\n    }\n  }\n}\n\n\nexport const events = _events;\n\nexport const eventsList = _eventsList;\n\nexport default { events: _events, eventsList: _eventsList };\n","export class BadRequestError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 400;\n    }\n}\n\nexport class UnauthorisedError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 401;\n    }\n}\n\nexport class ForbiddenError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 403;\n    }\n}\n\nexport class NotFoundError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 404;\n    }\n}\n\nexport class ConflictError extends Error {\n    constructor(message) {\n        super(message);\n        this.httpStatusCode = 409;\n    }\n}","import { cloneDeep, isUndefined } from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { UnauthorisedError } from './errors';\n\nexport const apiWrapper = async (app, eventNamespace, isAuthorized, eventContext, func, ...params) => {\n  pushCallStack(app, eventNamespace);\n\n  if (!isAuthorized(app)) {\n    handleNotAuthorized(app, eventContext, eventNamespace);\n    return;\n  }\n\n  const startDate = Date.now();\n  const elapsed = () => (Date.now() - startDate);\n\n  try {\n    await app.publish(\n      eventNamespace.onBegin,\n      eventContext,\n    );\n\n    const result = await func(...params);\n\n    await publishComplete(app, eventContext, eventNamespace, elapsed, result);\n    return result;\n  } catch (error) {\n    await publishError(app, eventContext, eventNamespace, elapsed, error);\n    throw error;\n  }\n};\n\nexport const apiWrapperSync = (app, eventNamespace, isAuthorized, eventContext, func, ...params) => {\n  pushCallStack(app, eventNamespace);\n\n  if (!isAuthorized(app)) {\n    handleNotAuthorized(app, eventContext, eventNamespace);\n    return;\n  }\n\n  const startDate = Date.now();\n  const elapsed = () => (Date.now() - startDate);\n\n  try {\n    app.publish(\n      eventNamespace.onBegin,\n      eventContext,\n    );\n\n    const result = func(...params);\n\n    publishComplete(app, eventContext, eventNamespace, elapsed, result);\n    return result;\n  } catch (error) {\n    publishError(app, eventContext, eventNamespace, elapsed, error);\n    throw error;\n  }\n};\n\nconst handleNotAuthorized = (app, eventContext, eventNamespace) => {\n  const err = new UnauthorisedError(`Unauthorized: ${eventNamespace}`);\n  publishError(app, eventContext, eventNamespace, () => 0, err);\n  throw err;\n};\n\nconst pushCallStack = (app, eventNamespace, seedCallId) => {\n  const callId = generate();\n\n  const createCallStack = () => ({\n    seedCallId: !isUndefined(seedCallId)\n      ? seedCallId\n      : callId,\n    threadCallId: callId,\n    stack: [],\n  });\n\n  if (isUndefined(app.calls)) {\n    app.calls = createCallStack();\n  }\n\n  app.calls.stack.push({\n    namespace: eventNamespace,\n    callId,\n  });\n};\n\nconst popCallStack = (app) => {\n  app.calls.stack.pop();\n  if (app.calls.stack.length === 0) {\n    delete app.calls;\n  }\n};\n\nconst publishError = async (app, eventContext, eventNamespace, elapsed, err) => {\n  const ctx = cloneDeep(eventContext);\n  ctx.error = err;\n  ctx.elapsed = elapsed();\n  await app.publish(\n    eventNamespace.onError,\n    ctx,\n  );\n  popCallStack(app);\n};\n\nconst publishComplete = async (app, eventContext, eventNamespace, elapsed, result) => {\n  const endcontext = cloneDeep(eventContext);\n  endcontext.result = result;\n  endcontext.elapsed = elapsed();\n  await app.publish(\n    eventNamespace.onComplete,\n    endcontext,\n  );\n  popCallStack(app);\n  return result;\n};\n\nexport default apiWrapper;\n","import { split } from 'lodash/fp';\nimport { $ } from './index';\n\nconst lockOverlapMilliseconds = 10;\n\nexport const getLock = async (app, lockFile, timeoutMilliseconds, maxLockRetries, retryCount = 0) => {\n  try {\n    const timeout = (await app.getEpochTime())\n            + timeoutMilliseconds;\n\n    const lock = {\n      timeout,\n      key: lockFile,\n      totalTimeout: timeoutMilliseconds,\n    };\n\n    await app.datastore.createFile(\n      lockFile,\n      getLockFileContent(\n        lock.totalTimeout,\n        lock.timeout,\n      ),\n    );\n\n    return lock;\n  } catch (e) {\n    if (retryCount == maxLockRetries) { return NO_LOCK; }\n\n    const lock = parseLockFileContent(\n      lockFile,\n      await app.datastore.loadFile(lockFile),\n    );\n\n    const currentEpochTime = await app.getEpochTime();\n\n    if (currentEpochTime < lock.timeout) {\n      return NO_LOCK;\n    }\n\n    try {\n      await app.datastore.deleteFile(lockFile);\n    } catch (_) {\n      //empty\n    }\n\n    await sleepForRetry();\n\n    return await getLock(\n      app, lockFile, timeoutMilliseconds,\n      maxLockRetries, retryCount + 1,\n    );\n  }\n};\n\nexport const getLockFileContent = (totalTimeout, epochTime) => `${totalTimeout}:${epochTime.toString()}`;\n\nconst parseLockFileContent = (key, content) => $(content, [\n  split(':'),\n  parts => ({\n    totalTimeout: new Number(parts[0]),\n    timeout: new Number(parts[1]),\n    key,\n  }),\n]);\n\nexport const releaseLock = async (app, lock) => {\n  const currentEpochTime = await app.getEpochTime();\n  // only release if not timedout\n  if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) {\n    try {\n      await app.datastore.deleteFile(lock.key);\n    } catch (_) {\n      //empty\n    }\n  }\n};\n\nexport const extendLock = async (app, lock) => {\n  const currentEpochTime = await app.getEpochTime();\n  // only release if not timedout\n  if (currentEpochTime < (lock.timeout - lockOverlapMilliseconds)) {\n    try {\n      lock.timeout = currentEpochTime + lock.timeoutMilliseconds;\n      await app.datastore.updateFile(\n        lock.key,\n        getLockFileContent(lock.totalTimeout, lock.timeout),\n      );\n      return lock;\n    } catch (_) {\n      //empty\n    }\n  }\n  return NO_LOCK;\n};\n\nexport const NO_LOCK = 'no lock';\nexport const isNolock = id => id === NO_LOCK;\n\nconst sleepForRetry = () => new Promise(resolve => setTimeout(resolve, lockOverlapMilliseconds));\n","import {\n  \n  head, \n  tail, findIndex, startsWith, \n  dropRight, flow, takeRight, trim,\n  replace\n} from 'lodash';\nimport { \n  some, reduce, isEmpty, isArray, join,\n  isString, isInteger, isDate, toNumber,\n  isUndefined, isNaN, isNull, constant,\n  split, includes, filter\n} from 'lodash/fp';\nimport { events, eventsList } from './events';\nimport { apiWrapper } from './apiWrapper';\nimport {\n  getLock, NO_LOCK,\n  isNolock\n} from './lock';\n\n// this is the combinator function\nexport const $$ = (...funcs) => arg => flow(funcs)(arg);\n\n// this is the pipe function\nexport const $ = (arg, funcs) => $$(...funcs)(arg);\n\nexport const keySep = '/';\nconst trimKeySep = str => trim(str, keySep);\nconst splitByKeySep = str => split(keySep)(str);\nexport const safeKey = key => replace(`${keySep}${trimKeySep(key)}`, `${keySep}${keySep}`, keySep);\nexport const joinKey = (...strs) => {\n  const paramsOrArray = strs.length === 1 & isArray(strs[0])\n    ? strs[0] : strs;\n  return $(paramsOrArray, [\n    filter(s => !isUndefined(s) \n                && !isNull(s) \n                && s.toString().length > 0),\n    join(keySep),\n    safeKey\n  ]);\n};\nexport const splitKey = $$(trimKeySep, splitByKeySep);\nexport const getDirFomKey = $$(splitKey, dropRight, p => joinKey(...p));\nexport const getFileFromKey = $$(splitKey, takeRight, head);\n\nexport const configFolder = `${keySep}.config`;\nexport const fieldDefinitions = joinKey(configFolder, 'fields.json');\nexport const templateDefinitions = joinKey(configFolder, 'templates.json');\nexport const appDefinitionFile = joinKey(configFolder, 'appDefinition.json');\nexport const dirIndex = folderPath => joinKey(configFolder, 'dir', ...splitKey(folderPath), 'dir.idx');\nexport const getIndexKeyFromFileKey = $$(getDirFomKey, dirIndex);\n\nexport const ifExists = (val, exists, notExists) => (isUndefined(val)\n  ? isUndefined(notExists) ? (() => { })() : notExists()\n  : exists());\n\nexport const getOrDefault = (val, defaultVal) => ifExists(val, () => val, () => defaultVal);\n\nexport const not = func => val => !func(val);\nexport const isDefined = not(isUndefined);\nexport const isNonNull = not(isNull);\nexport const isNotNaN = not(isNaN);\n\nexport const allTrue = (...funcArgs) => val => reduce(\n  (result, conditionFunc) => (isNull(result) || result == true) && conditionFunc(val),\n  null)(funcArgs);\n\nexport const anyTrue = (...funcArgs) => val => reduce(\n  (result, conditionFunc) => result == true || conditionFunc(val),\n  null)(funcArgs);\n\nexport const insensitiveEquals = (str1, str2) => str1.trim().toLowerCase() === str2.trim().toLowerCase();\n\nexport const isSomething = allTrue(isDefined, isNonNull, isNotNaN);\nexport const isNothing = not(isSomething);\nexport const isNothingOrEmpty = v => isNothing(v) || isEmpty(v);\nexport const somethingOrGetDefault = getDefaultFunc => val => (isSomething(val) ? val : getDefaultFunc());\nexport const somethingOrDefault = (val, defaultVal) => somethingOrGetDefault(constant(defaultVal))(val);\n\nexport const mapIfSomethingOrDefault = (mapFunc, defaultVal) => val => (isSomething(val) ? mapFunc(val) : defaultVal);\n\nexport const mapIfSomethingOrBlank = mapFunc => mapIfSomethingOrDefault(mapFunc, '');\n\nexport const none = predicate => collection => !some(predicate)(collection);\n\nexport const all = predicate => collection => none(v => !predicate(v))(collection);\n\nexport const isNotEmpty = ob => !isEmpty(ob);\nexport const isAsync = fn => fn.constructor.name === 'AsyncFunction';\nexport const isNonEmptyArray = allTrue(isArray, isNotEmpty);\nexport const isNonEmptyString = allTrue(isString, isNotEmpty);\nexport const tryOr = failFunc => (func, ...args) => {\n  try {\n    return func.apply(null, ...args);\n  } catch (_) {\n    return failFunc();\n  }\n};\n\nexport const tryAwaitOr = failFunc => async (func, ...args) => {\n  try {\n    return await func.apply(null, ...args);\n  } catch (_) {\n    return await failFunc();\n  }\n};\n\nexport const defineError = (func, errorPrefix) => {\n  try {\n    return func();\n  } catch (err) {\n    err.message = `${errorPrefix} : ${err.message}`;\n    throw err;\n  }\n};\n\nexport const tryOrIgnore = tryOr(() => { });\nexport const tryAwaitOrIgnore = tryAwaitOr(async () => { });\nexport const causesException = (func) => {\n  try {\n    func();\n    return false;\n  } catch (e) {\n    return true;\n  }\n};\n\nexport const executesWithoutException = func => !causesException(func);\n\nexport const handleErrorWith = returnValInError => tryOr(constant(returnValInError));\n\nexport const handleErrorWithUndefined = handleErrorWith(undefined);\n\nexport const switchCase = (...cases) => (value) => {\n  const nextCase = () => head(cases)[0](value);\n  const nextResult = () => head(cases)[1](value);\n\n  if (isEmpty(cases)) return; // undefined\n  if (nextCase() === true) return nextResult();\n  return switchCase(...tail(cases))(value);\n};\n\nexport const isValue = val1 => val2 => (val1 === val2);\nexport const isOneOf = (...vals) => val => includes(val)(vals);\nexport const defaultCase = constant(true);\nexport const memberMatches = (member, match) => obj => match(obj[member]);\n\n\nexport const StartsWith = searchFor => searchIn => startsWith(searchIn, searchFor);\n\nexport const contains = val => array => (findIndex(array, v => v === val) > -1);\n\nexport const getHashCode = (s) => {\n  let hash = 0; let i; let char; let\n    l;\n  if (s.length == 0) return hash;\n  for (i = 0, l = s.length; i < l; i++) {\n    char = s.charCodeAt(i);\n    hash = ((hash << 5) - hash) + char;\n    hash |= 0; // Convert to 32bit integer\n  }\n\n  // converting to string, but dont want a \"-\" prefixed\n  if (hash < 0) { return `n${(hash * -1).toString()}`; }\n  return hash.toString();\n};\n\n// thanks to https://blog.grossman.io/how-to-write-async-await-without-try-catch-blocks-in-javascript/\nexport const awEx = async (promise) => {\n  try {\n    const result = await promise;\n    return [undefined, result];\n  } catch (error) {\n    return [error, undefined];\n  }\n};\n\nexport const isSafeInteger = n => isInteger(n)\n    && n <= Number.MAX_SAFE_INTEGER\n    && n >= 0 - Number.MAX_SAFE_INTEGER;\n\nexport const toDateOrNull = s => (isNull(s) ? null\n  : isDate(s) ? s : new Date(s));\nexport const toBoolOrNull = s => (isNull(s) ? null\n  : s === 'true' || s === true);\nexport const toNumberOrNull = s => (isNull(s) ? null\n  : toNumber(s));\n\nexport const isArrayOfString = opts => isArray(opts) && all(isString)(opts);\n\nexport const pushAll = (target, items) => {\n  for(let i of items) target.push(i);\n}\n\nexport const pause = async duration => new Promise(res => setTimeout(res, duration));\n\nexport const retry = async (fn, retries, delay, ...args) => {\n  try {\n    return await fn(...args);\n  } catch (err) {\n    if (retries > 1) {\n      return await pause(delay).then(async () => await retry(fn, (retries - 1), delay, ...args));\n    }\n    throw err;\n  }\n};\n\nexport { events } from './events';\nexport { apiWrapper, apiWrapperSync } from './apiWrapper';\nexport {\n  getLock, NO_LOCK, releaseLock,\n  extendLock, isNolock,\n} from './lock';\n\nexport default {\n  ifExists,\n  getOrDefault,\n  isDefined,\n  isNonNull,\n  isNotNaN,\n  allTrue,\n  isSomething,\n  mapIfSomethingOrDefault,\n  mapIfSomethingOrBlank,\n  configFolder,\n  fieldDefinitions,\n  isNothing,\n  not,\n  switchCase,\n  defaultCase,\n  StartsWith,\n  contains,\n  templateDefinitions,\n  handleErrorWith,\n  handleErrorWithUndefined,\n  tryOr,\n  tryOrIgnore,\n  tryAwaitOr,\n  tryAwaitOrIgnore,\n  dirIndex,\n  keySep,\n  $,\n  $$,\n  getDirFomKey,\n  getFileFromKey,\n  splitKey,\n  somethingOrDefault,\n  getIndexKeyFromFileKey,\n  joinKey,\n  somethingOrGetDefault,\n  appDefinitionFile,\n  isValue,\n  all,\n  isOneOf,\n  memberMatches,\n  defineError,\n  anyTrue,\n  isNonEmptyArray,\n  causesException,\n  executesWithoutException,\n  none,\n  getHashCode,\n  awEx,\n  apiWrapper,\n  events,\n  eventsList,\n  isNothingOrEmpty,\n  isSafeInteger,\n  toNumber,\n  toDate: toDateOrNull,\n  toBool: toBoolOrNull,\n  isArrayOfString,\n  getLock,\n  NO_LOCK,\n  isNolock,\n  insensitiveEquals,\n  pause,\n  retry,\n  pushAll\n};\n","import { filter, map } from 'lodash/fp';\nimport { $, isSomething } from './index';\n\nexport const stringNotEmpty = s => isSomething(s) && s.trim().length > 0;\n\nexport const makerule = (field, error, isValid) => ({ field, error, isValid });\n\nexport const validationError = (rule, item) => ({ ...rule, item });\n\nexport const applyRuleSet = ruleSet => itemToValidate => $(ruleSet, [\n  map(applyRule(itemToValidate)),\n  filter(isSomething),\n]);\n\nexport const applyRule = itemTovalidate => rule => (rule.isValid(itemTovalidate)\n  ? null\n  : validationError(rule, itemTovalidate));\n","import { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  isUndefined, keys, \n  cloneDeep, isFunction,\n} from 'lodash/fp';\nimport { defineError } from '../common';\n\nexport const filterEval = 'FILTER_EVALUATE';\nexport const filterCompile = 'FILTER_COMPILE';\nexport const mapEval = 'MAP_EVALUATE';\nexport const mapCompile = 'MAP_COMPILE';\nexport const removeUndeclaredFields = 'REMOVE_UNDECLARED_FIELDS';\nexport const addUnMappedFields = 'ADD_UNMAPPED_FIELDS';\nexport const addTheKey = 'ADD_KEY';\n\n\nconst getEvaluateResult = () => ({\n  isError: false,\n  passedFilter: true,\n  result: null,\n});\n\nexport const compileFilter = index => compileExpression(index.filter);\n\nexport const compileMap = index => compileCode(index.map);\n\nexport const passesFilter = (record, index) => {\n  const context = { record };\n  if (!index.filter) return true;\n\n  const compiledFilter = defineError(\n    () => compileFilter(index),\n    filterCompile,\n  );\n\n  return defineError(\n    () => compiledFilter(context),\n    filterEval,\n  );\n};\n\nexport const mapRecord = (record, index) => {\n  const recordClone = cloneDeep(record);\n  const context = { record: recordClone };\n\n  const map = index.map ? index.map : 'return {...record};';\n\n  const compiledMap = defineError(\n    () => compileCode(map),\n    mapCompile,\n  );\n\n  const mapped = defineError(\n    () => compiledMap(context),\n    mapEval,\n  );\n\n  const mappedKeys = keys(mapped);\n  for (let i = 0; i < mappedKeys.length; i++) {\n    const key = mappedKeys[i];\n    mapped[key] = isUndefined(mapped[key]) ? null : mapped[key];\n    if (isFunction(mapped[key])) {\n      delete mapped[key];\n    }\n  }\n\n  mapped.key = record.key;\n  mapped.sortKey = index.getSortKey\n    ? compileCode(index.getSortKey)(context)\n    : record.id;\n\n  return mapped;\n};\n\nexport const evaluate = record => (index) => {\n  const result = getEvaluateResult();\n\n  try {\n    result.passedFilter = passesFilter(record, index);\n  } catch (err) {\n    result.isError = true;\n    result.passedFilter = false;\n    result.result = err.message;\n  }\n\n  if (!result.passedFilter) return result;\n\n  try {\n    result.result = mapRecord(record, index);\n  } catch (err) {\n    result.isError = true;\n    result.result = err.message;\n  }\n\n  return result;\n};\n\nexport default evaluate;\n","import {\n  map, isEmpty, countBy, \n  flatten, includes, join, keys\n} from 'lodash/fp';\nimport {  } from 'lodash';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { compileFilter, compileMap } from '../indexing/evaluate';\nimport { isNonEmptyString, executesWithoutException, $ } from '../common';\nimport { isRecord } from './hierarchy';\n\nexport const indexTypes = { reference: 'reference', ancestor: 'ancestor' };\n\nexport const indexRuleSet = [\n  makerule('map', 'index has no map function',\n    index => isNonEmptyString(index.map)),\n  makerule('map', \"index's map function does not compile\",\n    index => !isNonEmptyString(index.map)\n                || executesWithoutException(() => compileMap(index))),\n  makerule('filter', \"index's filter function does not compile\",\n    index => !isNonEmptyString(index.filter)\n                || executesWithoutException(() => compileFilter(index))),\n  makerule('name', 'must declare a name for index',\n    index => isNonEmptyString(index.name)),\n  makerule('name', 'there is a duplicate named index on this node',\n    index => isEmpty(index.name)\n                || countBy('name')(index.parent().indexes)[index.name] === 1),\n  makerule('indexType', 'reference index may only exist on a record node',\n    index => isRecord(index.parent())\n                  || index.indexType !== indexTypes.reference),\n  makerule('indexType', `index type must be one of: ${join(', ')(keys(indexTypes))}`,\n    index => includes(index.indexType)(keys(indexTypes))),\n];\n\nexport const validateIndex = (index, allReferenceIndexesOnNode) => applyRuleSet(indexRuleSet(allReferenceIndexesOnNode))(index);\n\nexport const validateAllIndexes = node => $(node.indexes, [\n  map(i => validateIndex(i, node.indexes)),\n  flatten,\n]);\n","import {\n  find, constant, map, last,\n  first, split, intersection, take,\n  union, includes, filter, some,\n} from 'lodash/fp';\nimport {\n  $, switchCase, isNothing, isSomething,\n  defaultCase, splitKey, isNonEmptyString,\n  joinKey, getHashCode,\n} from '../common';\nimport { indexTypes } from './indexes';\n\nexport const getFlattenedHierarchy = (appHierarchy, useCached = true) => {\n  if (isSomething(appHierarchy.getFlattenedHierarchy) && useCached) { return appHierarchy.getFlattenedHierarchy(); }\n\n  const flattenHierarchy = (currentNode, flattened) => {\n    flattened.push(currentNode);\n    if ((!currentNode.children\n            || currentNode.children.length === 0)\n            && (!currentNode.indexes\n            || currentNode.indexes.length === 0)\n            && (!currentNode.aggregateGroups\n            || currentNode.aggregateGroups.length === 0)) {\n      return flattened;\n    }\n\n    const unionIfAny = l2 => l1 => union(l1)(!l2 ? [] : l2);\n\n    const children = $([], [\n      unionIfAny(currentNode.children),\n      unionIfAny(currentNode.indexes),\n      unionIfAny(currentNode.aggregateGroups),\n    ]);\n\n    for (const child of children) {\n      flattenHierarchy(child, flattened);\n    }\n    return flattened;\n  };\n\n  appHierarchy.getFlattenedHierarchy = () => flattenHierarchy(appHierarchy, []);\n  return appHierarchy.getFlattenedHierarchy();\n};\n\nexport const getLastPartInKey = key => last(splitKey(key));\n\nexport const getNodesInPath = appHierarchy => key => $(appHierarchy, [\n  getFlattenedHierarchy,\n  filter(n => new RegExp(`${n.pathRegx()}`).test(key)),\n]);\n\nexport const getExactNodeForKey = appHierarchy => key => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => new RegExp(`${n.pathRegx()}$`).test(key)),\n]);\n\nexport const getNodeForCollectionPath = appHierarchy => collectionKey => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => (isCollectionRecord(n)\n                   && new RegExp(`${n.collectionPathRegx()}$`).test(collectionKey))),\n]);\n\nexport const hasMatchingAncestor = ancestorPredicate => decendantNode => switchCase(\n\n  [node => isNothing(node.parent()),\n    constant(false)],\n\n  [node => ancestorPredicate(node.parent()),\n    constant(true)],\n\n  [defaultCase,\n    node => hasMatchingAncestor(ancestorPredicate)(node.parent())],\n\n)(decendantNode);\n\nexport const getNode = (appHierarchy, nodeKey) => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => n.nodeKey() === nodeKey\n                  || (isCollectionRecord(n)\n                      && n.collectionNodeKey() === nodeKey)),\n]);\n\nexport const getCollectionNode = (appHierarchy, nodeKey) => $(appHierarchy, [\n  getFlattenedHierarchy,\n  find(n => (isCollectionRecord(n)\n                    && n.collectionNodeKey() === nodeKey)),\n]);\n\nexport const getNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => {\n  const nodeByKey = getExactNodeForKey(appHierarchy)(keyOrNodeKey);\n  return isNothing(nodeByKey)\n    ? getNode(appHierarchy, keyOrNodeKey)\n    : nodeByKey;\n};\n\nexport const getCollectionNodeByKeyOrNodeKey = (appHierarchy, keyOrNodeKey) => {\n  const nodeByKey = getNodeForCollectionPath(appHierarchy)(keyOrNodeKey);\n  return isNothing(nodeByKey)\n    ? getCollectionNode(appHierarchy, keyOrNodeKey)\n    : nodeByKey;\n};\n\nexport const isNode = (appHierarchy, key) => isSomething(getExactNodeForKey(appHierarchy)(key));\n\nexport const getActualKeyOfParent = (parentNodeKey, actualChildKey) => \n  $(actualChildKey, [\n    splitKey,\n    take(splitKey(parentNodeKey).length),\n    ks => joinKey(...ks),\n  ]);\n\nexport const getParentKey = (key) => {\n  return $(key, [\n    splitKey,\n    take(splitKey(key).length - 1),\n    joinKey,\n  ]);\n};\n\nexport const isKeyAncestorOf = ancestorKey => decendantNode => hasMatchingAncestor(p => p.nodeKey() === ancestorKey)(decendantNode);\n\nexport const hasNoMatchingAncestors = parentPredicate => node => !hasMatchingAncestor(parentPredicate)(node);\n\nexport const findField = (recordNode, fieldName) => find(f => f.name == fieldName)(recordNode.fields);\n\nexport const isAncestor = decendant => ancestor => isKeyAncestorOf(ancestor.nodeKey())(decendant);\n\nexport const isDecendant = ancestor => decendant => isAncestor(decendant)(ancestor);\n\nexport const getRecordNodeId = recordKey => $(recordKey, [\n  splitKey,\n  last,\n  getRecordNodeIdFromId,\n]);\n\nexport const getRecordNodeIdFromId = recordId => $(recordId, [split('-'), first, parseInt]);\n\nexport const getRecordNodeById = (hierarchy, recordId) => $(hierarchy, [\n  getFlattenedHierarchy,\n  find(n => isRecord(n)\n                    && n.nodeId === getRecordNodeIdFromId(recordId)),\n]);\n\nexport const recordNodeIdIsAllowed = indexNode => nodeId => indexNode.allowedRecordNodeIds.length === 0\n    || includes(nodeId)(indexNode.allowedRecordNodeIds);\n\nexport const recordNodeIsAllowed = indexNode => recordNode => recordNodeIdIsAllowed(indexNode)(recordNode.nodeId);\n\nexport const getAllowedRecordNodesForIndex = (appHierarchy, indexNode) => {\n  const recordNodes = $(appHierarchy, [\n    getFlattenedHierarchy,\n    filter(isRecord),\n  ]);\n\n  if (isGlobalIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(recordNodeIsAllowed(indexNode)),\n    ]);\n  }\n\n  if (isAncestorIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(isDecendant(indexNode.parent())),\n      filter(recordNodeIsAllowed(indexNode)),\n    ]);\n  }\n\n  if (isReferenceIndex(indexNode)) {\n    return $(recordNodes, [\n      filter(n => some(fieldReversesReferenceToIndex(indexNode))(n.fields)),\n    ]);\n  }\n};\n\nexport const getNodeFromNodeKeyHash = hierarchy => hash => $(hierarchy, [\n  getFlattenedHierarchy,\n  find(n => getHashCode(n.nodeKey()) === hash),\n]);\n\nexport const isRecord = node => isSomething(node) && node.type === 'record';\nexport const isSingleRecord = node => isRecord(node) && node.isSingle;\nexport const isCollectionRecord = node => isRecord(node) && !node.isSingle;\nexport const isIndex = node => isSomething(node) && node.type === 'index';\nexport const isaggregateGroup = node => isSomething(node) && node.type === 'aggregateGroup';\nexport const isShardedIndex = node => isIndex(node) && isNonEmptyString(node.getShardName);\nexport const isRoot = node => isSomething(node) && node.isRoot();\nexport const isDecendantOfARecord = hasMatchingAncestor(isRecord);\nexport const isGlobalIndex = node => isIndex(node) && isRoot(node.parent());\nexport const isReferenceIndex = node => isIndex(node) && node.indexType === indexTypes.reference;\nexport const isAncestorIndex = node => isIndex(node) && node.indexType === indexTypes.ancestor;\n\nexport const fieldReversesReferenceToNode = node => field => field.type === 'reference'\n    && intersection(field.typeOptions.reverseIndexNodeKeys)(map(i => i.nodeKey())(node.indexes))\n      .length > 0;\n\nexport const fieldReversesReferenceToIndex = indexNode => field => field.type === 'reference'\n    && intersection(field.typeOptions.reverseIndexNodeKeys)([indexNode.nodeKey()])\n      .length > 0;\n\nexport default {\n  getLastPartInKey,\n  getNodesInPath,\n  getExactNodeForKey,\n  hasMatchingAncestor,\n  getNode,\n  getNodeByKeyOrNodeKey,\n  isNode,\n  getActualKeyOfParent,\n  getParentKey,\n  isKeyAncestorOf,\n  hasNoMatchingAncestors,\n  findField,\n  isAncestor,\n  isDecendant,\n  getRecordNodeId,\n  getRecordNodeIdFromId,\n  getRecordNodeById,\n  recordNodeIdIsAllowed,\n  recordNodeIsAllowed,\n  getAllowedRecordNodesForIndex,\n  getNodeFromNodeKeyHash,\n  isRecord,\n  isCollectionRecord,\n  isIndex,\n  isaggregateGroup,\n  isShardedIndex,\n  isRoot,\n  isDecendantOfARecord,\n  isGlobalIndex,\n  isReferenceIndex,\n  isAncestorIndex,\n  fieldReversesReferenceToNode,\n  fieldReversesReferenceToIndex,\n  getFlattenedHierarchy,\n};\n","import { merge } from 'lodash';\nimport {\n  constant, isUndefined, has,\n  mapValues, cloneDeep,\n} from 'lodash/fp';\nimport { isNotEmpty } from '../common';\n\nexport const getSafeFieldParser = (tryParse, defaultValueFunctions) => (field, record) => {\n  if (has(field.name)(record)) {\n    return getSafeValueParser(tryParse, defaultValueFunctions)(record[field.name]);\n  }\n  return defaultValueFunctions[field.getUndefinedValue]();\n};\n\nexport const getSafeValueParser = (tryParse, defaultValueFunctions) => (value) => {\n  const parsed = tryParse(value);\n  if (parsed.success) {\n    return parsed.value;\n  }\n  return defaultValueFunctions.default();\n};\n\nexport const getNewValue = (tryParse, defaultValueFunctions) => (field) => {\n  const getInitialValue = isUndefined(field) || isUndefined(field.getInitialValue)\n    ? 'default'\n    : field.getInitialValue;\n\n  return has(getInitialValue)(defaultValueFunctions)\n    ? defaultValueFunctions[getInitialValue]()\n    : getSafeValueParser(tryParse, defaultValueFunctions)(getInitialValue);\n};\n\nexport const typeFunctions = specificFunctions => merge({\n  value: constant,\n  null: constant(null),\n}, specificFunctions);\n\nexport const validateTypeConstraints = validationRules => async (field, record, context) => {\n  const fieldValue = record[field.name];\n  const validateRule = async r => (!await r.isValid(fieldValue, field.typeOptions, context)\n    ? r.getMessage(fieldValue, field.typeOptions)\n    : '');\n\n  const errors = [];\n  for (const r of validationRules) {\n    const err = await validateRule(r);\n    if (isNotEmpty(err)) errors.push(err);\n  }\n\n  return errors;\n};\n\nconst getDefaultOptions = mapValues(v => v.defaultValue);\n\nexport const makerule = (isValid, getMessage) => ({ isValid, getMessage });\nexport const parsedFailed = val => ({ success: false, value: val });\nexport const parsedSuccess = val => ({ success: true, value: val });\nexport const getDefaultExport = (name, tryParse, functions, options, validationRules, sampleValue, stringify) => ({\n  getNew: getNewValue(tryParse, functions),\n  safeParseField: getSafeFieldParser(tryParse, functions),\n  safeParseValue: getSafeValueParser(tryParse, functions),\n  tryParse,\n  name,\n  getDefaultOptions: () => getDefaultOptions(cloneDeep(options)),\n  optionDefinitions: options,\n  validateTypeConstraints: validateTypeConstraints(validationRules),\n  sampleValue,\n  stringify: val => (val === null || val === undefined\n    ? '' : stringify(val)),\n  getDefaultValue: functions.default,\n});\n","import {\n  constant, isString,\n  isNull, includes, isBoolean,\n} from 'lodash/fp';\nimport {\n  typeFunctions,\n  makerule, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toBoolOrNull, toNumberOrNull,\n  isSafeInteger, isArrayOfString,\n} from '../common';\n\nconst stringFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst stringTryParse = switchCase(\n  [isString, parsedSuccess],\n  [isNull, parsedSuccess],\n  [defaultCase, v => parsedSuccess(v.toString())],\n);\n\nconst options = {\n  maxLength: {\n    defaultValue: null,\n    isValid: n => n === null || isSafeInteger(n) && n > 0,\n    requirementDescription: 'max length must be null (no limit) or a greater than zero integer',\n    parse: toNumberOrNull,\n  },\n  values: {\n    defaultValue: null,\n    isValid: v => v === null || (isArrayOfString(v) && v.length > 0 && v.length < 10000),\n    requirementDescription: \"'values' must be null (no values) or an arry of at least one string\",\n    parse: s => s,\n  },\n  allowDeclaredValuesOnly: {\n    defaultValue: false,\n    isValid: isBoolean,\n    requirementDescription: 'allowDeclaredValuesOnly must be true or false',\n    parse: toBoolOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.maxLength === null || val.length <= opts.maxLength,\n    (val, opts) => `value exceeds maximum length of ${opts.maxLength}`),\n  makerule(async (val, opts) => val === null\n                           || opts.allowDeclaredValuesOnly === false\n                           || includes(val)(opts.values),\n  (val) => `\"${val}\" does not exist in the list of allowed values`),\n];\n\nexport default getDefaultExport(\n  'string',\n  stringTryParse,\n  stringFunctions,\n  options,\n  typeConstraints,\n  'abcde',\n  str => str,\n);\n","import { constant, isBoolean, isNull } from 'lodash/fp';\nimport {\n  typeFunctions,\n  makerule, parsedFailed, parsedSuccess,\n  getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, isOneOf, toBoolOrNull,\n} from '../common';\n\nconst boolFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst boolTryParse = switchCase(\n  [isBoolean, parsedSuccess],\n  [isNull, parsedSuccess],\n  [isOneOf('true', '1', 'yes', 'on'), () => parsedSuccess(true)],\n  [isOneOf('false', '0', 'no', 'off'), () => parsedSuccess(false)],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  allowNulls: {\n    defaultValue: true,\n    isValid: isBoolean,\n    requirementDescription: 'must be a true or false',\n    parse: toBoolOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => opts.allowNulls === true || val !== null,\n    () => 'field cannot be null'),\n];\n\nexport default getDefaultExport(\n  'bool', boolTryParse, boolFunctions,\n  options, typeConstraints, true, JSON.stringify,\n);\n","import {\n  constant, isNumber, isString, isNull,\n} from 'lodash/fp';\nimport {\n  makerule, typeFunctions,\n  parsedFailed, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toNumberOrNull,\n  isSafeInteger,\n} from '../common';\n\nconst numberFunctions = typeFunctions({\n  default: constant(null),\n});\n\nconst parseStringtoNumberOrNull = (s) => {\n  const num = Number(s);\n  return isNaN(num) ? parsedFailed(s) : parsedSuccess(num);\n};\n\nconst numberTryParse = switchCase(\n  [isNumber, parsedSuccess],\n  [isString, parseStringtoNumberOrNull],\n  [isNull, parsedSuccess],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  maxValue: {\n    defaultValue: Number.MAX_SAFE_INTEGER,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a valid integer',\n    parse: toNumberOrNull,\n  },\n  minValue: {\n    defaultValue: 0 - Number.MAX_SAFE_INTEGER,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a valid integer',\n    parse: toNumberOrNull,\n  },\n  decimalPlaces: {\n    defaultValue: 0,\n    isValid: n => isSafeInteger(n) && n >= 0,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n};\n\nconst getDecimalPlaces = (val) => {\n  const splitDecimal = val.toString().split('.');\n  if (splitDecimal.length === 1) return 0;\n  return splitDecimal[1].length;\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue,\n    (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`),\n  makerule(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue,\n    (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`),\n  makerule(async (val, opts) => val === null || opts.decimalPlaces >= getDecimalPlaces(val),\n    (val, opts) => `value (${val.toString()}) must have ${opts.decimalPlaces} decimal places or less`),\n];\n\nexport default getDefaultExport(\n  'number',\n  numberTryParse,\n  numberFunctions,\n  options,\n  typeConstraints,\n  1,\n  num => num.toString(),\n);\n","import {\n  constant, isDate, isString, isNull\n} from 'lodash/fp';\nimport {\n  makerule, typeFunctions,\n  parsedFailed, parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toDateOrNull,\n} from '../common';\n\nconst dateFunctions = typeFunctions({\n  default: constant(null),\n  now: () => new Date(),\n});\n\nconst isValidDate = d => d instanceof Date && !isNaN(d);\n\nconst parseStringToDate = s => switchCase(\n  [isValidDate, parsedSuccess],\n  [defaultCase, parsedFailed],\n)(new Date(s));\n\n\nconst dateTryParse = switchCase(\n  [isDate, parsedSuccess],\n  [isString, parseStringToDate],\n  [isNull, parsedSuccess],\n  [defaultCase, parsedFailed],\n);\n\nconst options = {\n  maxValue: {\n    defaultValue: new Date(32503680000000),\n    isValid: isDate,\n    requirementDescription: 'must be a valid date',\n    parse: toDateOrNull,\n  },\n  minValue: {\n    defaultValue: new Date(-8520336000000),\n    isValid: isDate,\n    requirementDescription: 'must be a valid date',\n    parse: toDateOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || opts.minValue === null || val >= opts.minValue,\n    (val, opts) => `value (${val.toString()}) must be greater than or equal to ${opts.minValue}`),\n  makerule(async (val, opts) => val === null || opts.maxValue === null || val <= opts.maxValue,\n    (val, opts) => `value (${val.toString()}) must be less than or equal to ${opts.minValue} options`),\n];\n\nexport default getDefaultExport(\n  'datetime',\n  dateTryParse,\n  dateFunctions,\n  options,\n  typeConstraints,\n  new Date(1984, 4, 1),\n  date => JSON.stringify(date).replace(new RegExp('\"', 'g'), ''),\n);\n","import { \n  map,  constant, isArray \n} from 'lodash/fp';\nimport {\n  typeFunctions, makerule,\n  parsedFailed, getDefaultExport, parsedSuccess,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, toNumberOrNull,\n  $$, isSafeInteger,\n} from '../common';\n\nconst arrayFunctions = () => typeFunctions({\n  default: constant([]),\n});\n\nconst mapToParsedArrary = type => $$(\n  map(i => type.safeParseValue(i)),\n  parsedSuccess,\n);\n\nconst arrayTryParse = type => switchCase(\n  [isArray, mapToParsedArrary(type)],\n  [defaultCase, parsedFailed],\n);\n\nconst typeName = type => `array<${type}>`;\n\n\nconst options = {\n  maxLength: {\n    defaultValue: 10000,\n    isValid: isSafeInteger,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n  minLength: {\n    defaultValue: 0,\n    isValid: n => isSafeInteger(n) && n >= 0,\n    requirementDescription: 'must be a positive integer',\n    parse: toNumberOrNull,\n  },\n};\n\nconst typeConstraints = [\n  makerule(async (val, opts) => val === null || val.length >= opts.minLength,\n    (val, opts) => `must choose ${opts.minLength} or more options`),\n  makerule(async (val, opts) => val === null || val.length <= opts.maxLength,\n    (val, opts) => `cannot choose more than ${opts.maxLength} options`),\n];\n\nexport default type => getDefaultExport(\n  typeName(type.name),\n  arrayTryParse(type),\n  arrayFunctions(type),\n  options,\n  typeConstraints,\n  [type.sampleValue],\n  JSON.stringify,\n);\n","import {\n  isString, isObjectLike,\n  isNull, has, isEmpty,\n} from 'lodash/fp';\nimport {\n  typeFunctions, makerule,\n  parsedSuccess, getDefaultExport,\n  parsedFailed,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase,\n  isNonEmptyString, isArrayOfString,\n} from '../common';\n\nconst referenceNothing = () => ({ key: '' });\n\nconst referenceFunctions = typeFunctions({\n  default: referenceNothing,\n});\n\nconst hasStringValue = (ob, path) => has(path)(ob)\n    && isString(ob[path]);\n\nconst isObjectWithKey = v => isObjectLike(v)\n    && hasStringValue(v, 'key');\n\nconst tryParseFromString = s => {\n\n  try {\n    const asObj = JSON.parse(s);\n    if(isObjectWithKey) {\n      return parsedSuccess(asObj);\n    }\n  }\n  catch(_) {\n    // EMPTY\n  }\n\n  return parsedFailed(s);\n}\n\nconst referenceTryParse = v => switchCase(\n  [isObjectWithKey, parsedSuccess],\n  [isString, tryParseFromString],\n  [isNull, () => parsedSuccess(referenceNothing())],\n  [defaultCase, parsedFailed],\n)(v);\n\nconst options = {\n  indexNodeKey: {\n    defaultValue: null,\n    isValid: isNonEmptyString,\n    requirementDescription: 'must be a non-empty string',\n    parse: s => s,\n  },\n  displayValue: {\n    defaultValue: '',\n    isValid: isNonEmptyString,\n    requirementDescription: 'must be a non-empty string',\n    parse: s => s,\n  },\n  reverseIndexNodeKeys: {\n    defaultValue: null,\n    isValid: v => isArrayOfString(v) && v.length > 0,\n    requirementDescription: 'must be a non-empty array of strings',\n    parse: s => s,\n  },\n};\n\nconst isEmptyString = s => isString(s) && isEmpty(s);\n\nconst ensureReferenceExists = async (val, opts, context) => isEmptyString(val.key)\n    || await context.referenceExists(opts, val.key);\n\nconst typeConstraints = [\n  makerule(\n    ensureReferenceExists,\n    (val, opts) => `\"${val[opts.displayValue]}\" does not exist in options list (key: ${val.key})`,\n  ),\n];\n\nexport default getDefaultExport(\n  'reference',\n  referenceTryParse,\n  referenceFunctions,\n  options,\n  typeConstraints,\n  { key: 'key', value: 'value' },\n  JSON.stringify,\n);\n","import {\n  last, has, isString, intersection,\n  isNull, isNumber,\n} from 'lodash/fp';\nimport {\n  typeFunctions, parsedFailed,\n  parsedSuccess, getDefaultExport,\n} from './typeHelpers';\nimport {\n  switchCase, defaultCase, none,\n  $, splitKey,\n} from '../common';\n\nconst illegalCharacters = '*?\\\\/:<>|\\0\\b\\f\\v';\n\nexport const isLegalFilename = (filePath) => {\n  const fn = fileName(filePath);\n  return fn.length <= 255\n    && intersection(fn.split(''))(illegalCharacters.split('')).length === 0\n    && none(f => f === '..')(splitKey(filePath));\n};\n\nconst fileNothing = () => ({ relativePath: '', size: 0 });\n\nconst fileFunctions = typeFunctions({\n  default: fileNothing,\n});\n\nconst fileTryParse = v => switchCase(\n  [isValidFile, parsedSuccess],\n  [isNull, () => parsedSuccess(fileNothing())],\n  [defaultCase, parsedFailed],\n)(v);\n\nconst fileName = filePath => $(filePath, [\n  splitKey,\n  last,\n]);\n\nconst isValidFile = f => !isNull(f)\n    && has('relativePath')(f) && has('size')(f)\n    && isNumber(f.size)\n    && isString(f.relativePath)\n    && isLegalFilename(f.relativePath);\n\nconst options = {};\n\nconst typeConstraints = [];\n\nexport default getDefaultExport(\n  'file',\n  fileTryParse,\n  fileFunctions,\n  options,\n  typeConstraints,\n  { relativePath: 'some_file.jpg', size: 1000 },\n  JSON.stringify,\n);\n","import {\n  assign, merge, \n} from 'lodash';\nimport {\n  map, isString, isNumber,\n  isBoolean, isDate, keys,\n  isObject, isArray, has\n} from 'lodash/fp';\nimport { $ } from '../common';\nimport { parsedSuccess } from './typeHelpers';\nimport string from './string';\nimport bool from './bool';\nimport number from './number';\nimport datetime from './datetime';\nimport array from './array';\nimport reference from './reference';\nimport file from './file';\nimport { BadRequestError } from '../common/errors';\n\nconst allTypes = () => {\n  const basicTypes = {\n    string, number, datetime, bool, reference, file,\n  };\n\n  const arrays = $(basicTypes, [\n    keys,\n    map((k) => {\n      const kvType = {};\n      const concreteArray = array(basicTypes[k]);\n      kvType[concreteArray.name] = concreteArray;\n      return kvType;\n    }),\n    types => assign({}, ...types),\n  ]);\n\n  return merge({}, basicTypes, arrays);\n};\n\n\nexport const all = allTypes();\n\nexport const getType = (typeName) => {\n  if (!has(typeName)(all)) throw new BadRequestError(`Do not recognise type ${typeName}`);\n  return all[typeName];\n};\n\nexport const getSampleFieldValue = field => getType(field.type).sampleValue;\n\nexport const getNewFieldValue = field => getType(field.type).getNew(field);\n\nexport const safeParseField = (field, record) => getType(field.type).safeParseField(field, record);\n\nexport const validateFieldParse = (field, record) => (has(field.name)(record)\n  ? getType(field.type).tryParse(record[field.name])\n  : parsedSuccess(undefined)); // fields may be undefined by default\n\nexport const getDefaultOptions = type => getType(type).getDefaultOptions();\n\nexport const validateTypeConstraints = async (field, record, context) => await getType(field.type).validateTypeConstraints(field, record, context);\n\nexport const detectType = (value) => {\n  if (isString(value)) return string;\n  if (isBoolean(value)) return bool;\n  if (isNumber(value)) return number;\n  if (isDate(value)) return datetime;\n  if (isArray(value)) return array(detectType(value[0]));\n  if (isObject(value)\n       && has('key')(value)\n       && has('value')(value)) return reference;\n  if (isObject(value)\n        && has('relativePath')(value)\n        && has('size')(value)) return file;\n\n  throw new BadRequestError(`cannot determine type: ${JSON.stringify(value)}`);\n};\n","import { clone, find, split } from 'lodash/fp';\nimport { joinKey, $ } from '../common';\n// 5 minutes\nexport const tempCodeExpiryLength = 5 * 60 * 1000;\n\nexport const AUTH_FOLDER = '/.auth';\nexport const USERS_LIST_FILE = joinKey(AUTH_FOLDER, 'users.json');\nexport const userAuthFile = username => joinKey(AUTH_FOLDER, `auth_${username}.json`);\nexport const USERS_LOCK_FILE = joinKey(AUTH_FOLDER, 'users_lock');\nexport const ACCESS_LEVELS_FILE = joinKey(AUTH_FOLDER, 'access_levels.json');\nexport const ACCESS_LEVELS_LOCK_FILE = joinKey(AUTH_FOLDER, 'access_levels_lock');\n\nexport const permissionTypes = {\n  CREATE_RECORD: 'create record',\n  UPDATE_RECORD: 'update record',\n  READ_RECORD: 'read record',\n  DELETE_RECORD: 'delete record',\n  READ_INDEX: 'read index',\n  MANAGE_INDEX: 'manage index',\n  MANAGE_COLLECTION: 'manage collection',\n  WRITE_TEMPLATES: 'write templates',\n  CREATE_USER: 'create user',\n  SET_PASSWORD: 'set password',\n  CREATE_TEMPORARY_ACCESS: 'create temporary access',\n  ENABLE_DISABLE_USER: 'enable or disable user',\n  WRITE_ACCESS_LEVELS: 'write access levels',\n  LIST_USERS: 'list users',\n  LIST_ACCESS_LEVELS: 'list access levels',\n  EXECUTE_ACTION: 'execute action',\n  SET_USER_ACCESS_LEVELS: 'set user access levels',\n};\n\nexport const getUserByName = (users, name) => $(users, [\n  find(u => u.name.toLowerCase() === name.toLowerCase()),\n]);\n\nexport const stripUserOfSensitiveStuff = (user) => {\n  const stripped = clone(user);\n  delete stripped.tempCode;\n  return stripped;\n};\n\nexport const parseTemporaryCode = fullCode => $(fullCode, [\n  split(':'),\n  parts => ({\n    id: parts[1],\n    code: parts[2],\n  }),\n]);\n","import { values, includes, some } from 'lodash/fp';\nimport { permissionTypes } from './authCommon';\nimport {\n  $, isNothing, apiWrapperSync, events,\n} from '../common';\nimport { getNodeByKeyOrNodeKey, isNode } from '../templateApi/hierarchy';\nimport { alwaysAuthorized } from './permissions';\n\nexport const isAuthorized = app => (permissionType, resourceKey) => apiWrapperSync(\n  app,\n  events.authApi.isAuthorized,\n  alwaysAuthorized,\n  { resourceKey, permissionType },\n  _isAuthorized, app, permissionType, resourceKey,\n);\n\nexport const _isAuthorized = (app, permissionType, resourceKey) => {\n  if (!app.user) {\n    return false;\n  }\n\n  const validType = $(permissionTypes, [\n    values,\n    includes(permissionType),\n  ]);\n\n  if (!validType) {\n    return false;\n  }\n\n  const permMatchesResource = (userperm) => {\n    const nodeKey = isNothing(resourceKey)\n      ? null\n      : isNode(app.hierarchy, resourceKey)\n        ? getNodeByKeyOrNodeKey(\n          app.hierarchy, resourceKey,\n        ).nodeKey()\n        : resourceKey;\n\n    return (userperm.type === permissionType)\n        && (\n          isNothing(resourceKey)\n            || nodeKey === userperm.nodeKey\n        );\n  };\n\n  return $(app.user.permissions, [\n    some(permMatchesResource),\n  ]);\n};\n","import { permissionTypes } from './authCommon';\nimport { isAuthorized } from './isAuthorized';\n\nexport const temporaryAccessPermissions = () => ([{ type: permissionTypes.SET_PASSWORD }]);\n\nconst nodePermission = type => ({\n  add: (nodeKey, accessLevel) => accessLevel.permissions.push({ type, nodeKey }),\n  isAuthorized: resourceKey => app => isAuthorized(app)(type, resourceKey),\n  isNode: true,\n  get: nodeKey => ({ type, nodeKey }),\n});\n\nconst staticPermission = type => ({\n  add: accessLevel => accessLevel.permissions.push({ type }),\n  isAuthorized: app => isAuthorized(app)(type),\n  isNode: false,\n  get: () => ({ type }),\n});\n\nconst createRecord = nodePermission(permissionTypes.CREATE_RECORD);\n\nconst updateRecord = nodePermission(permissionTypes.UPDATE_RECORD);\n\nconst deleteRecord = nodePermission(permissionTypes.DELETE_RECORD);\n\nconst readRecord = nodePermission(permissionTypes.READ_RECORD);\n\nconst writeTemplates = staticPermission(permissionTypes.WRITE_TEMPLATES);\n\nconst createUser = staticPermission(permissionTypes.CREATE_USER);\n\nconst setPassword = staticPermission(permissionTypes.SET_PASSWORD);\n\nconst readIndex = nodePermission(permissionTypes.READ_INDEX);\n\nconst manageIndex = staticPermission(permissionTypes.MANAGE_INDEX);\n\nconst manageCollection = staticPermission(permissionTypes.MANAGE_COLLECTION);\n\nconst createTemporaryAccess = staticPermission(permissionTypes.CREATE_TEMPORARY_ACCESS);\n\nconst enableDisableUser = staticPermission(permissionTypes.ENABLE_DISABLE_USER);\n\nconst writeAccessLevels = staticPermission(permissionTypes.WRITE_ACCESS_LEVELS);\n\nconst listUsers = staticPermission(permissionTypes.LIST_USERS);\n\nconst listAccessLevels = staticPermission(permissionTypes.LIST_ACCESS_LEVELS);\n\nconst setUserAccessLevels = staticPermission(permissionTypes.SET_USER_ACCESS_LEVELS);\n\nconst executeAction = nodePermission(permissionTypes.EXECUTE_ACTION);\n\nexport const alwaysAuthorized = () => true;\n\nexport const permission = {\n  createRecord,\n  updateRecord,\n  deleteRecord,\n  readRecord,\n  writeTemplates,\n  createUser,\n  setPassword,\n  readIndex,\n  createTemporaryAccess,\n  enableDisableUser,\n  writeAccessLevels,\n  listUsers,\n  listAccessLevels,\n  manageIndex,\n  manageCollection,\n  executeAction,\n  setUserAccessLevels,\n};\n","import {\n  keyBy, mapValues,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { \n  getNodeForCollectionPath, isSingleRecord \n} from '../templateApi/hierarchy';\nimport { getNewFieldValue } from '../types';\nimport {\n  $, joinKey, safeKey, apiWrapperSync, events,\n} from '../common';\nimport { permission } from '../authApi/permissions';\n\nexport const getNew = app => (collectionKey, recordTypeName) => {\n  const recordNode = getRecordNode(app, collectionKey, recordTypeName);\n  collectionKey=safeKey(collectionKey);\n  return apiWrapperSync(\n    app,\n    events.recordApi.getNew,\n    permission.createRecord.isAuthorized(recordNode.nodeKey()),\n    { collectionKey, recordTypeName },\n    _getNew, recordNode, collectionKey,\n  );\n};\n\nexport const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey);\n\nconst getRecordNode = (app, collectionKey) => {\n  collectionKey = safeKey(collectionKey);\n  return getNodeForCollectionPath(app.hierarchy)(collectionKey);\n};\n\nexport const getNewChild = app => (recordKey, collectionName, recordTypeName) => \n  getNew(app)(joinKey(recordKey, collectionName), recordTypeName);\n\nexport const constructRecord = (recordNode, getFieldValue, collectionKey) => {\n  const record = $(recordNode.fields, [\n    keyBy('name'),\n    mapValues(getFieldValue),\n  ]);\n\n  record.id = `${recordNode.nodeId}-${generate()}`;\n  record.key = isSingleRecord(recordNode)\n               ? joinKey(collectionKey, recordNode.name)\n               : joinKey(collectionKey, record.id);\n  record.isNew = true;\n  record.type = recordNode.name;\n  return record;\n};\n","import {\n  flatten, orderBy,\n  filter, isUndefined\n} from 'lodash/fp';\nimport hierarchy, {\n  getFlattenedHierarchy,\n  getCollectionNodeByKeyOrNodeKey,\n  isCollectionRecord, isAncestor,\n} from '../templateApi/hierarchy';\nimport { joinKey, safeKey, $ } from '../common';\nimport { getCollectionDir } from \"../recordApi/recordInfo\";\n\nexport const RECORDS_PER_FOLDER = 1000;\nexport const allIdChars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_-';\n\n// this should never be changed - ever \n// - existing databases depend on the order of chars this string\n\n/**\n * folderStructureArray should return an array like\n * - [1] = all records fit into one folder\n * - [2] = all records fite into 2 folders\n * - [64, 3] = all records fit into 64 * 3 folders\n * - [64, 64, 10] = all records fit into 64 * 64 * 10 folder\n * (there are 64 possible chars in allIsChars) \n*/\nexport const folderStructureArray = (recordNode) => {\n\n  const totalFolders = Math.ceil(recordNode.estimatedRecordCount / 1000);\n  const folderArray = [];\n  let levelCount = 1;\n  while(64**levelCount < totalFolders) {\n    levelCount += 1;\n    folderArray.push(64);\n  }\n\n  const parentFactor = (64**folderArray.length);\n  if(parentFactor < totalFolders) {\n    folderArray.push(\n      Math.ceil(totalFolders / parentFactor)\n    );\n  }  \n\n  return folderArray;\n\n  /*\n  const maxRecords = currentFolderPosition === 0 \n                     ? RECORDS_PER_FOLDER\n                     : currentFolderPosition * 64 * RECORDS_PER_FOLDER;\n\n  if(maxRecords < recordNode.estimatedRecordCount) {\n    return folderStructureArray(\n            recordNode,\n            [...currentArray, 64], \n            currentFolderPosition + 1);\n  } else {\n    const childFolderCount = Math.ceil(recordNode.estimatedRecordCount / maxRecords );\n    return [...currentArray, childFolderCount]\n  }*/\n}\n\n\nexport const getAllIdsIterator = app => async (collection_Key_or_NodeKey) => {\n  collection_Key_or_NodeKey = safeKey(collection_Key_or_NodeKey);\n  const recordNode = getCollectionNodeByKeyOrNodeKey(\n    app.hierarchy,\n    collection_Key_or_NodeKey,\n  );\n\n  const getAllIdsIteratorForCollectionKey = async (recordNode, collectionKey) => {\n    \n    const folderStructure = folderStructureArray(recordNode)\n\n    let currentFolderContents = [];\n    let currentPosition = [];\n\n    const collectionDir = getCollectionDir(app.hierarchy, collectionKey);\n    const basePath = joinKey(\n      collectionDir, recordNode.nodeId.toString());\n  \n\n    \n    // \"folderStructure\" determines the top, sharding folders\n    // we need to add one, for the collection root folder, which\n    // always  exists \n    const levels = folderStructure.length + 1;\n    const topLevel = levels -1;\n\n   \n    /* populate initial directory structure in form:\n    [\n      {path: \"/a\", contents: [\"b\", \"c\", \"d\"]}, \n      {path: \"/a/b\", contents: [\"e\",\"f\",\"g\"]},\n      {path: \"/a/b/e\", contents: [\"1-abcd\",\"2-cdef\",\"3-efgh\"]}, \n    ]\n    // stores contents on each parent level\n    // top level has ID folders \n    */\n    const firstFolder = async () => {\n\n      let folderLevel = 0;\n\n      const lastPathHasContent = () => \n        folderLevel === 0 \n        || currentFolderContents[folderLevel - 1].contents.length > 0;\n\n\n      while (folderLevel <= topLevel && lastPathHasContent()) {\n\n        let thisPath = basePath;\n        for(let lev = 0; lev < currentPosition.length; lev++) {\n          thisPath = joinKey(\n            thisPath, currentFolderContents[lev].contents[0]);\n        }\n\n        const contentsThisLevel = \n          await app.datastore.getFolderContents(thisPath);\n        currentFolderContents.push({\n            contents:contentsThisLevel, \n            path: thisPath\n        });   \n\n        // should start as something like [0,0]\n        if(folderLevel < topLevel)\n          currentPosition.push(0); \n\n        folderLevel+=1;\n      }\n\n      return (currentPosition.length === levels - 1);\n    }  \n\n    const isOnLastFolder = level => {\n      \n      const result =  currentPosition[level] === currentFolderContents[level].contents.length - 1;\n      return result;\n    }\n    \n    const getNextFolder = async (lev=undefined) => {\n      lev = isUndefined(lev) ? topLevel : lev;\n      const parentLev = lev - 1;\n\n      if(parentLev < 0) return false;\n      \n      if(isOnLastFolder(parentLev)) { \n        return await getNextFolder(parentLev);\n      }\n\n      const newPosition = currentPosition[parentLev] + 1;\n      currentPosition[parentLev] = newPosition;\n      \n      const nextFolder = joinKey(\n        currentFolderContents[parentLev].path,\n        currentFolderContents[parentLev].contents[newPosition]);\n      currentFolderContents[lev].contents = await app.datastore.getFolderContents(\n        nextFolder\n      );\n      currentFolderContents[lev].path = nextFolder;\n\n      if(lev !== topLevel) {\n      \n        // we just advanced a parent folder, so now need to\n        // do the same to the next levels\n        let loopLevel = lev + 1;\n        while(loopLevel <= topLevel) {\n          const loopParentLevel = loopLevel-1;\n          \n          currentPosition[loopParentLevel] = 0;\n          const nextLoopFolder = joinKey(\n            currentFolderContents[loopParentLevel].path,\n            currentFolderContents[loopParentLevel].contents[0]);\n          currentFolderContents[loopLevel].contents = await app.datastore.getFolderContents(\n            nextLoopFolder\n          );\n          currentFolderContents[loopLevel].path = nextLoopFolder;\n          loopLevel+=1;\n        }\n      }\n\n      // true ==has more ids... (just loaded more)\n      return true;\n    }\n\n\n    const idsCurrentFolder = () => \n      currentFolderContents[currentFolderContents.length - 1].contents;\n\n    const fininshedResult = ({ done: true, result: { ids: [], collectionKey } });\n\n    let hasStarted = false;\n    let hasMore = true;\n    const getIdsFromCurrentfolder = async () => {\n\n      if(!hasMore) {\n        return fininshedResult;\n      }\n\n      if(!hasStarted) {\n        hasMore = await firstFolder();\n        hasStarted = true;\n        return ({\n          result: {\n            ids: idsCurrentFolder(),\n            collectionKey\n          },\n          done: false\n        })\n      }\n\n      hasMore = await getNextFolder();\n      \n      return ({\n        result: {\n          ids: hasMore ? idsCurrentFolder() : [],\n          collectionKey\n        },\n        done: !hasMore\n      });\n    }\n\n    return getIdsFromCurrentfolder;\n    \n  };\n\n  const ancestors = $(getFlattenedHierarchy(app.hierarchy), [\n    filter(isCollectionRecord),\n    filter(n => isAncestor(recordNode)(n)\n                    || n.nodeKey() === recordNode.nodeKey()),\n    orderBy([n => n.nodeKey().length], ['asc']),\n  ]); // parents first\n\n  const traverseForIteraterators = async (parentRecordKey = '', currentNodeIndex = 0) => {\n    const currentNode = ancestors[currentNodeIndex];\n    const currentCollectionKey = joinKey(\n      parentRecordKey,\n      currentNode.collectionName,\n    );\n    if (currentNode.nodeKey() === recordNode.nodeKey()) {\n      return [\n        await getAllIdsIteratorForCollectionKey(\n          currentNode,\n          currentCollectionKey,\n        )];\n    }\n    const allIterators = [];\n    const currentIterator = await getAllIdsIteratorForCollectionKey(\n      currentNode,\n      currentCollectionKey,\n    );\n\n    let ids = await currentIterator();\n    while (ids.done === false) {\n      for (const id of ids.result.ids) {\n        allIterators.push(\n          await traverseForIteraterators(\n            joinKey(currentCollectionKey, id),\n            currentNodeIndex + 1,\n          ),\n        );\n      }\n\n      ids = await currentIterator();\n    }\n\n    return flatten(allIterators);\n  };\n\n  const iteratorsArray = await traverseForIteraterators();\n  let currentIteratorIndex = 0;\n  return async () => {\n    if (iteratorsArray.length === 0) { return { done: true, result: [] }; }\n    const innerResult = await iteratorsArray[currentIteratorIndex]();\n    if (!innerResult.done) { return innerResult; }\n    if (currentIteratorIndex == iteratorsArray.length - 1) {\n      return { done: true, result: innerResult.result };\n    }\n    currentIteratorIndex++;\n    return { done: false, result: innerResult.result };\n  };\n};\n\n\nexport default getAllIdsIterator;\n","import { \n  getExactNodeForKey, getActualKeyOfParent, \n  isRoot, isSingleRecord, getNodeForCollectionPath\n} from '../templateApi/hierarchy';\nimport {\nreduce, find, filter, take\n} from 'lodash/fp';\nimport {\n$, getFileFromKey, joinKey, safeKey, keySep\n} from '../common';\nimport { \n    folderStructureArray, allIdChars \n} from \"../indexing/allIds\";\n\nexport const getRecordInfo = (hierarchy, key) => {\n  const recordNode = getExactNodeForKey(hierarchy)(key);\n  const pathInfo = getRecordDirectory(recordNode, key);\n  const dir = joinKey(pathInfo.base, ...pathInfo.subdirs);\n\n  return {\n    recordJson: recordJson(dir),\n    files: files(dir),\n    child:(name) => joinKey(dir, name),\n    key: safeKey(key),\n    recordNode, pathInfo, dir\n  };\n}\n\nexport const getCollectionDir = (hierarchy, collectionKey) => {\n  const recordNode = getNodeForCollectionPath(hierarchy)(collectionKey);\n  const dummyRecordKey = joinKey(collectionKey, \"1-abcd\");\n  const pathInfo = getRecordDirectory(recordNode, dummyRecordKey);\n  return pathInfo.base;\n}\n\nconst recordJson = (dir) => \n  joinKey(dir, \"record.json\")\n\nconst files = (dir) => \n  joinKey(dir, \"files\")\n\nconst getRecordDirectory = (recordNode, key) => {\n  const id = getFileFromKey(key);\n  \n  const traverseParentKeys = (n, parents=[]) => {\n    if(isRoot(n)) return parents;\n    const k = getActualKeyOfParent(n.nodeKey(), key);\n    const thisNodeDir = {\n      node:n,\n      relativeDir: joinKey(\n        recordRelativeDirectory(n, getFileFromKey(k)))\n    };\n    return traverseParentKeys(\n      n.parent(), \n      [thisNodeDir, ...parents]);\n  }\n\n  const parentDirs = $(recordNode.parent(), [\n    traverseParentKeys,\n    reduce((key, item) => {\n      return joinKey(key, item.node.collectionName, item.relativeDir)\n    }, keySep)\n  ]);\n\n  const subdirs = isSingleRecord(recordNode)\n                  ? []\n                  : recordRelativeDirectory(recordNode, id);\n  const base = isSingleRecord(recordNode)\n               ? joinKey(parentDirs, recordNode.name)\n               : joinKey(parentDirs, recordNode.collectionName);\n\n  return ({\n    subdirs, base\n  });\n}\n\nconst recordRelativeDirectory = (recordNode, id) => {\n  const folderStructure = folderStructureArray(recordNode);\n  const strippedId = id.substring(recordNode.nodeId.toString().length + 1);\n  const subfolders = $(folderStructure, [\n    reduce((result, currentCount) => {\n      result.folders.push(\n          folderForChar(strippedId[result.level], currentCount)\n      );\n      return {level:result.level+1, folders:result.folders};\n    }, {level:0, folders:[]}),\n    f => f.folders,\n    filter(f => !!f)\n  ]);\n\n  return [recordNode.nodeId.toString(), ...subfolders, id]\n}\n\nconst folderForChar = (char, folderCount) => \n  folderCount === 1 ? \"\"\n  : $(folderCount, [\n      idFoldersForFolderCount,\n      find(f => f.includes(char))\n    ]);\n\nconst idFoldersForFolderCount = (folderCount) => {\n  const charRangePerShard = 64 / folderCount;\n  const idFolders = [];\n  let index = 0;\n  let currentIdsShard = '';\n  while (index < 64) {\n    currentIdsShard += allIdChars[index];\n    if ((index + 1) % charRangePerShard === 0) {\n      idFolders.push(currentIdsShard);\n      currentIdsShard = '';\n    }\n    index++;\n  }\n    \n    return idFolders;\n};\n\n","import {\n  keyBy, mapValues, filter, \n  map, includes, last,\n} from 'lodash/fp';\nimport { getExactNodeForKey, getNode } from '../templateApi/hierarchy';\nimport { safeParseField } from '../types';\nimport {\n  $, splitKey, safeKey, isNonEmptyString,\n  apiWrapper, events, joinKey,\n} from '../common';\nimport { mapRecord } from '../indexing/evaluate';\nimport { permission } from '../authApi/permissions';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const getRecordFileName = key => joinKey(key, 'record.json');\n\nexport const load = app => async key => {\n  key = safeKey(key);\n  return apiWrapper(\n    app,\n    events.recordApi.load,\n    permission.readRecord.isAuthorized(key),\n    { key },\n    _load, app, key,\n  );\n}\n\nexport const _loadFromInfo = async (app, recordInfo, keyStack = []) => {\n  const key = recordInfo.key;\n  const {recordNode, recordJson} = recordInfo;\n  const storedData = await app.datastore.loadJson(recordJson);\n\n  const loadedRecord = $(recordNode.fields, [\n    keyBy('name'),\n    mapValues(f => safeParseField(f, storedData)),\n  ]);\n\n  const newKeyStack = [...keyStack, key];\n\n  const references = $(recordNode.fields, [\n    filter(f => f.type === 'reference'\n                    && isNonEmptyString(loadedRecord[f.name].key)\n                    && !includes(loadedRecord[f.name].key)(newKeyStack)),\n    map(f => ({\n      promise: _load(app, loadedRecord[f.name].key, newKeyStack),\n      index: getNode(app.hierarchy, f.typeOptions.indexNodeKey),\n      field: f,\n    })),\n  ]);\n\n  if (references.length > 0) {\n    const refRecords = await Promise.all(\n      map(p => p.promise)(references),\n    );\n\n    for (const ref of references) {\n      loadedRecord[ref.field.name] = mapRecord(\n        refRecords[references.indexOf(ref)],\n        ref.index,\n      );\n    }\n  }\n\n  loadedRecord.transactionId = storedData.transactionId;\n  loadedRecord.isNew = false;\n  loadedRecord.key = key;\n  loadedRecord.id = $(key, [splitKey, last]);\n  loadedRecord.type = recordNode.name;\n  return loadedRecord;\n};\n\nexport const _load = async (app, key, keyStack = []) => \n  _loadFromInfo(\n    app,\n    getRecordInfo(app.hierarchy, key),\n    keyStack);\n\n\nexport default load;\n","// adapted from https://github.com/dex4er/js-promise-readable\n// thanks :)\n  \nexport const promiseReadableStream = stream => {\n   \n    let _errored;\n\n    const _errorHandler = err => {\n        _errored = err;\n    };\n\n    stream.on(\"error\", _errorHandler);\n  \n    const read = (size) => {\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err)\n        }\n  \n        if (!stream.readable || stream.closed || stream.destroyed) {\n          return resolve();\n        }\n  \n        const readableHandler = () => {\n          const chunk = stream.read(size);\n  \n          if (chunk) {\n            removeListeners();\n            resolve(chunk);\n          }\n        }\n  \n        const closeHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const endHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const errorHandler = (err) => {\n          _errored = undefined;\n          removeListeners();\n          reject(err);\n        }\n  \n        const removeListeners = () => {\n          stream.removeListener(\"close\", closeHandler);\n          stream.removeListener(\"error\", errorHandler);\n          stream.removeListener(\"end\", endHandler);\n          stream.removeListener(\"readable\", readableHandler);\n        }\n  \n        stream.on(\"close\", closeHandler);\n        stream.on(\"end\", endHandler);\n        stream.on(\"error\", errorHandler);\n        stream.on(\"readable\", readableHandler);\n  \n        readableHandler();\n      });\n    }\n  \n  \n    const destroy = () => {\n      if (stream) {\n        if (_errorHandler) {\n          stream.removeListener(\"error\", _errorHandler);\n        }\n        if (typeof stream.destroy === \"function\") {\n          stream.destroy();\n        }\n      }\n    };\n  \n    return {read, destroy, stream};\n  }\n  \n  export default promiseReadableStream\n  ","import { compileCode } from '@nx-js/compiler-util';\nimport {\n  filter, includes, map, last,\n} from 'lodash/fp';\nimport {\n  getActualKeyOfParent, isGlobalIndex,\n  getParentKey, isShardedIndex,\n  getExactNodeForKey,\n} from '../templateApi/hierarchy';\nimport {\n  joinKey, isNonEmptyString, splitKey, $,\n} from '../common';\n\nexport const getIndexedDataKey = (indexNode, indexDir, record) => {\n  \n  const getShardName = (indexNode, record) => {\n    const shardNameFunc = compileCode(indexNode.getShardName);\n    try {\n      return shardNameFunc({ record });\n    } catch(e) {\n      const errorDetails = `shardCode: ${indexNode.getShardName} :: record: ${JSON.stringify(record)} :: `\n      e.message = \"Error running index shardname func: \" + errorDetails + e.message;\n      throw e;\n    }\n  };\n\n  const shardName = isNonEmptyString(indexNode.getShardName)\n    ? `${getShardName(indexNode, record)}.csv`\n    : 'index.csv';\n\n  return joinKey(indexDir, shardName);\n};\n\nexport const getShardKeysInRange = async (app, indexNode, indexDir, startRecord = null, endRecord = null) => {\n  const startShardName = !startRecord\n    ? null\n    : shardNameFromKey(\n      getIndexedDataKey(\n        indexNode,\n        indexDir,\n        startRecord,\n      ),\n    );\n\n  const endShardName = !endRecord\n    ? null\n    : shardNameFromKey(\n      getIndexedDataKey(\n        indexNode,\n        indexDir,\n        endRecord,\n      ),\n    );\n\n  return $(await getShardMap(app.datastore, indexDir), [\n    filter(k => (startRecord === null || k >= startShardName)\n                    && (endRecord === null || k <= endShardName)),\n    map(k => joinKey(indexDir, `${k}.csv`)),\n  ]);\n};\n\nexport const ensureShardNameIsInShardMap = async (store, indexDir, indexedDataKey) => {\n  const map = await getShardMap(store, indexDir);\n  const shardName = shardNameFromKey(indexedDataKey);\n  if (!includes(shardName)(map)) {\n    map.push(shardName);\n    await writeShardMap(store, indexDir, map);\n  }\n};\n\nexport const getShardMap = async (datastore, indexDir) => {\n  const shardMapKey = getShardMapKey(indexDir);\n  try {\n    return await datastore.loadJson(shardMapKey);\n  } catch (_) {\n    await datastore.createJson(shardMapKey, []);\n    return [];\n  }\n};\n\nexport const writeShardMap = async (datastore, indexDir, shardMap) => await datastore.updateJson(\n  getShardMapKey(indexDir),\n  shardMap,\n);\n\nexport const getAllShardKeys = async (app, indexNode, indexDir) =>\n  await getShardKeysInRange(app, indexNode, indexDir);\n\nexport const getShardMapKey = indexDir => joinKey(indexDir, 'shardMap.json');\n\nexport const getUnshardedIndexDataKey = indexDir => joinKey(indexDir, 'index.csv');\n\nexport const createIndexFile = async (datastore, indexedDataKey, index) => {\n  if (isShardedIndex(index)) {\n    const indexDir = getParentKey(indexedDataKey);\n    const shardMap = await getShardMap(datastore, indexDir);\n    shardMap.push(\n      shardNameFromKey(indexedDataKey),\n    );\n    await writeShardMap(datastore, indexDir, shardMap);\n  }\n  await datastore.createFile(indexedDataKey, '');\n};\n\nexport const shardNameFromKey = key => $(key, [\n  splitKey,\n  last,\n]).replace('.csv', '');\n\nexport const getIndexKey_BasedOnDecendant = (decendantKey, indexNode) => {\n  if (isGlobalIndex(indexNode)) { return `${indexNode.nodeKey()}`; }\n\n  const indexedDataParentKey = getActualKeyOfParent(\n    indexNode.parent().nodeKey(),\n    decendantKey,\n  );\n\n  return joinKey(\n    indexedDataParentKey,\n    indexNode.name,\n  );\n};\n","import {\n  has, keys, map, orderBy,\n  filter, concat, reverse,\n} from 'lodash/fp';\nimport { getAllowedRecordNodesForIndex } from '../templateApi/hierarchy';\nimport { mapRecord } from './evaluate';\nimport { constructRecord } from '../recordApi/getNew';\nimport { getSampleFieldValue, detectType, all } from '../types';\nimport { $ } from '../common';\n\nexport const generateSchema = (hierarchy, indexNode) => {\n  const recordNodes = getAllowedRecordNodesForIndex(hierarchy, indexNode);\n  const mappedRecords = $(recordNodes, [\n    map(n => mapRecord(createSampleRecord(n), indexNode)),\n  ]);\n\n  // always has record key and sort key\n  const schema = {\n    sortKey: all.string,\n    key: all.string,\n  };\n\n  const fieldsHas = has(schema);\n  const setField = (fieldName, value) => {\n    if (value === null || value === undefined) { return; }\n\n    const thisType = detectType(value);\n    if (fieldsHas(fieldName)) {\n      if (schema[fieldName] !== thisType) {\n        schema[fieldName] = all.string;\n      }\n    } else {\n      schema[fieldName] = thisType;\n    }\n  };\n\n  for (const mappedRec of mappedRecords) {\n    for (const f in mappedRec) {\n      setField(f, mappedRec[f]);\n    }\n  }\n\n  // returing an array of {name, type}\n  return $(schema, [\n    keys,\n    map(k => ({ name: k, type: schema[k].name })),\n    filter(s => s.name !== 'sortKey'),\n    orderBy('name', ['desc']), // reverse aplha\n    concat([{ name: 'sortKey', type: all.string.name }]), // sortKey on end\n    reverse, // sortKey first, then rest are alphabetical\n  ]);\n};\n\nconst createSampleRecord = recordNode => constructRecord(\n  recordNode,\n  getSampleFieldValue,\n  recordNode.parent().nodeKey(),\n);\n","export default (typeof global !== \"undefined\" ? global :\n            typeof self !== \"undefined\" ? self :\n            typeof window !== \"undefined\" ? window : {});\n","\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\nvar inited = false;\nfunction init () {\n  inited = true;\n  var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\n  for (var i = 0, len = code.length; i < len; ++i) {\n    lookup[i] = code[i]\n    revLookup[code.charCodeAt(i)] = i\n  }\n\n  revLookup['-'.charCodeAt(0)] = 62\n  revLookup['_'.charCodeAt(0)] = 63\n}\n\nexport function toByteArray (b64) {\n  if (!inited) {\n    init();\n  }\n  var i, j, l, tmp, placeHolders, arr\n  var len = b64.length\n\n  if (len % 4 > 0) {\n    throw new Error('Invalid string. Length must be a multiple of 4')\n  }\n\n  // the number of equal signs (place holders)\n  // if there are two placeholders, than the two characters before it\n  // represent one byte\n  // if there is only one, then the three characters before it represent 2 bytes\n  // this is just a cheap hack to not do indexOf twice\n  placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n\n  // base64 is 4/3 + up to two characters of the original data\n  arr = new Arr(len * 3 / 4 - placeHolders)\n\n  // if there are placeholders, only get up to the last complete 4 chars\n  l = placeHolders > 0 ? len - 4 : len\n\n  var L = 0\n\n  for (i = 0, j = 0; i < l; i += 4, j += 3) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n    arr[L++] = (tmp >> 16) & 0xFF\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  if (placeHolders === 2) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n    arr[L++] = tmp & 0xFF\n  } else if (placeHolders === 1) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  return arr\n}\n\nfunction tripletToBase64 (num) {\n  return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n  var tmp\n  var output = []\n  for (var i = start; i < end; i += 3) {\n    tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n    output.push(tripletToBase64(tmp))\n  }\n  return output.join('')\n}\n\nexport function fromByteArray (uint8) {\n  if (!inited) {\n    init();\n  }\n  var tmp\n  var len = uint8.length\n  var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n  var output = ''\n  var parts = []\n  var maxChunkLength = 16383 // must be multiple of 3\n\n  // go through the array every three bytes, we'll deal with trailing stuff later\n  for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n    parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n  }\n\n  // pad the end with zeros, but make sure to not forget the extra bytes\n  if (extraBytes === 1) {\n    tmp = uint8[len - 1]\n    output += lookup[tmp >> 2]\n    output += lookup[(tmp << 4) & 0x3F]\n    output += '=='\n  } else if (extraBytes === 2) {\n    tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n    output += lookup[tmp >> 10]\n    output += lookup[(tmp >> 4) & 0x3F]\n    output += lookup[(tmp << 2) & 0x3F]\n    output += '='\n  }\n\n  parts.push(output)\n\n  return parts.join('')\n}\n","\nexport function read (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexport function write (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","var toString = {}.toString;\n\nexport default Array.isArray || function (arr) {\n  return toString.call(arr) == '[object Array]';\n};\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n/* eslint-disable no-proto */\n\n\nimport * as base64 from './base64'\nimport * as ieee754 from './ieee754'\nimport isArray from './isArray'\n\nexport var INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n *   - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n *     See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *   - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n *   - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n *     incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n  ? global.TYPED_ARRAY_SUPPORT\n  : true\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nvar _kMaxLength = kMaxLength()\nexport {_kMaxLength as kMaxLength};\nfunction typedArraySupport () {\n  return true;\n  // rollup issues\n  // try {\n  //   var arr = new Uint8Array(1)\n  //   arr.__proto__ = {\n  //     __proto__: Uint8Array.prototype,\n  //     foo: function () { return 42 }\n  //   }\n  //   return arr.foo() === 42 && // typed array instances can be augmented\n  //       typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n  //       arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  // } catch (e) {\n  //   return false\n  // }\n}\n\nfunction kMaxLength () {\n  return Buffer.TYPED_ARRAY_SUPPORT\n    ? 0x7fffffff\n    : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n  if (kMaxLength() < length) {\n    throw new RangeError('Invalid typed array length')\n  }\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = new Uint8Array(length)\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    if (that === null) {\n      that = new Buffer(length)\n    }\n    that.length = length\n  }\n\n  return that\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nexport function Buffer (arg, encodingOrOffset, length) {\n  if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n    return new Buffer(arg, encodingOrOffset, length)\n  }\n\n  // Common case.\n  if (typeof arg === 'number') {\n    if (typeof encodingOrOffset === 'string') {\n      throw new Error(\n        'If encoding is specified then the first argument must be a string'\n      )\n    }\n    return allocUnsafe(this, arg)\n  }\n  return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n  arr.__proto__ = Buffer.prototype\n  return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n  if (typeof value === 'number') {\n    throw new TypeError('\"value\" argument must not be a number')\n  }\n\n  if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n    return fromArrayBuffer(that, value, encodingOrOffset, length)\n  }\n\n  if (typeof value === 'string') {\n    return fromString(that, value, encodingOrOffset)\n  }\n\n  return fromObject(that, value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n  return from(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n  Buffer.prototype.__proto__ = Uint8Array.prototype\n  Buffer.__proto__ = Uint8Array\n  if (typeof Symbol !== 'undefined' && Symbol.species &&\n      Buffer[Symbol.species] === Buffer) {\n    // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n    // Object.defineProperty(Buffer, Symbol.species, {\n    //   value: null,\n    //   configurable: true\n    // })\n  }\n}\n\nfunction assertSize (size) {\n  if (typeof size !== 'number') {\n    throw new TypeError('\"size\" argument must be a number')\n  } else if (size < 0) {\n    throw new RangeError('\"size\" argument must not be negative')\n  }\n}\n\nfunction alloc (that, size, fill, encoding) {\n  assertSize(size)\n  if (size <= 0) {\n    return createBuffer(that, size)\n  }\n  if (fill !== undefined) {\n    // Only pay attention to encoding if it's a string. This\n    // prevents accidentally sending in a number that would\n    // be interpretted as a start offset.\n    return typeof encoding === 'string'\n      ? createBuffer(that, size).fill(fill, encoding)\n      : createBuffer(that, size).fill(fill)\n  }\n  return createBuffer(that, size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n  return alloc(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n  assertSize(size)\n  that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < size; ++i) {\n      that[i] = 0\n    }\n  }\n  return that\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n  return allocUnsafe(null, size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n  return allocUnsafe(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') {\n    encoding = 'utf8'\n  }\n\n  if (!Buffer.isEncoding(encoding)) {\n    throw new TypeError('\"encoding\" must be a valid string encoding')\n  }\n\n  var length = byteLength(string, encoding) | 0\n  that = createBuffer(that, length)\n\n  var actual = that.write(string, encoding)\n\n  if (actual !== length) {\n    // Writing a hex string, for example, that contains invalid characters will\n    // cause everything after the first invalid character to be ignored. (e.g.\n    // 'abxxcd' will be treated as 'ab')\n    that = that.slice(0, actual)\n  }\n\n  return that\n}\n\nfunction fromArrayLike (that, array) {\n  var length = array.length < 0 ? 0 : checked(array.length) | 0\n  that = createBuffer(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n  array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n  if (byteOffset < 0 || array.byteLength < byteOffset) {\n    throw new RangeError('\\'offset\\' is out of bounds')\n  }\n\n  if (array.byteLength < byteOffset + (length || 0)) {\n    throw new RangeError('\\'length\\' is out of bounds')\n  }\n\n  if (byteOffset === undefined && length === undefined) {\n    array = new Uint8Array(array)\n  } else if (length === undefined) {\n    array = new Uint8Array(array, byteOffset)\n  } else {\n    array = new Uint8Array(array, byteOffset, length)\n  }\n\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = array\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that = fromArrayLike(that, array)\n  }\n  return that\n}\n\nfunction fromObject (that, obj) {\n  if (internalIsBuffer(obj)) {\n    var len = checked(obj.length) | 0\n    that = createBuffer(that, len)\n\n    if (that.length === 0) {\n      return that\n    }\n\n    obj.copy(that, 0, 0, len)\n    return that\n  }\n\n  if (obj) {\n    if ((typeof ArrayBuffer !== 'undefined' &&\n        obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n      if (typeof obj.length !== 'number' || isnan(obj.length)) {\n        return createBuffer(that, 0)\n      }\n      return fromArrayLike(that, obj)\n    }\n\n    if (obj.type === 'Buffer' && isArray(obj.data)) {\n      return fromArrayLike(that, obj.data)\n    }\n  }\n\n  throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < kMaxLength()` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= kMaxLength()) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + kMaxLength().toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nexport function SlowBuffer (length) {\n  if (+length != length) { // eslint-disable-line eqeqeq\n    length = 0\n  }\n  return Buffer.alloc(+length)\n}\nBuffer.isBuffer = isBuffer;\nfunction internalIsBuffer (b) {\n  return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n  if (!internalIsBuffer(a) || !internalIsBuffer(b)) {\n    throw new TypeError('Arguments must be Buffers')\n  }\n\n  if (a === b) return 0\n\n  var x = a.length\n  var y = b.length\n\n  for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n    if (a[i] !== b[i]) {\n      x = a[i]\n      y = b[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'latin1':\n    case 'binary':\n    case 'base64':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function concat (list, length) {\n  if (!isArray(list)) {\n    throw new TypeError('\"list\" argument must be an Array of Buffers')\n  }\n\n  if (list.length === 0) {\n    return Buffer.alloc(0)\n  }\n\n  var i\n  if (length === undefined) {\n    length = 0\n    for (i = 0; i < list.length; ++i) {\n      length += list[i].length\n    }\n  }\n\n  var buffer = Buffer.allocUnsafe(length)\n  var pos = 0\n  for (i = 0; i < list.length; ++i) {\n    var buf = list[i]\n    if (!internalIsBuffer(buf)) {\n      throw new TypeError('\"list\" argument must be an Array of Buffers')\n    }\n    buf.copy(buffer, pos)\n    pos += buf.length\n  }\n  return buffer\n}\n\nfunction byteLength (string, encoding) {\n  if (internalIsBuffer(string)) {\n    return string.length\n  }\n  if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n      (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n    return string.byteLength\n  }\n  if (typeof string !== 'string') {\n    string = '' + string\n  }\n\n  var len = string.length\n  if (len === 0) return 0\n\n  // Use a for loop to avoid recursion\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'ascii':\n      case 'latin1':\n      case 'binary':\n        return len\n      case 'utf8':\n      case 'utf-8':\n      case undefined:\n        return utf8ToBytes(string).length\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return len * 2\n      case 'hex':\n        return len >>> 1\n      case 'base64':\n        return base64ToBytes(string).length\n      default:\n        if (loweredCase) return utf8ToBytes(string).length // assume utf8\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n  var loweredCase = false\n\n  // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n  // property of a typed array.\n\n  // This behaves neither like String nor Uint8Array in that we set start/end\n  // to their upper/lower bounds if the value passed is out of range.\n  // undefined is handled specially as per ECMA-262 6th Edition,\n  // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n  if (start === undefined || start < 0) {\n    start = 0\n  }\n  // Return early if start > this.length. Done here to prevent potential uint32\n  // coercion fail below.\n  if (start > this.length) {\n    return ''\n  }\n\n  if (end === undefined || end > this.length) {\n    end = this.length\n  }\n\n  if (end <= 0) {\n    return ''\n  }\n\n  // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n  end >>>= 0\n  start >>>= 0\n\n  if (end <= start) {\n    return ''\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Slice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n  var i = b[n]\n  b[n] = b[m]\n  b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n  var len = this.length\n  if (len % 2 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 16-bits')\n  }\n  for (var i = 0; i < len; i += 2) {\n    swap(this, i, i + 1)\n  }\n  return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n  var len = this.length\n  if (len % 4 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 32-bits')\n  }\n  for (var i = 0; i < len; i += 4) {\n    swap(this, i, i + 3)\n    swap(this, i + 1, i + 2)\n  }\n  return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n  var len = this.length\n  if (len % 8 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 64-bits')\n  }\n  for (var i = 0; i < len; i += 8) {\n    swap(this, i, i + 7)\n    swap(this, i + 1, i + 6)\n    swap(this, i + 2, i + 5)\n    swap(this, i + 3, i + 4)\n  }\n  return this\n}\n\nBuffer.prototype.toString = function toString () {\n  var length = this.length | 0\n  if (length === 0) return ''\n  if (arguments.length === 0) return utf8Slice(this, 0, length)\n  return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n  if (!internalIsBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return true\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n  var str = ''\n  var max = INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max) str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n  if (!internalIsBuffer(target)) {\n    throw new TypeError('Argument must be a Buffer')\n  }\n\n  if (start === undefined) {\n    start = 0\n  }\n  if (end === undefined) {\n    end = target ? target.length : 0\n  }\n  if (thisStart === undefined) {\n    thisStart = 0\n  }\n  if (thisEnd === undefined) {\n    thisEnd = this.length\n  }\n\n  if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n    throw new RangeError('out of range index')\n  }\n\n  if (thisStart >= thisEnd && start >= end) {\n    return 0\n  }\n  if (thisStart >= thisEnd) {\n    return -1\n  }\n  if (start >= end) {\n    return 1\n  }\n\n  start >>>= 0\n  end >>>= 0\n  thisStart >>>= 0\n  thisEnd >>>= 0\n\n  if (this === target) return 0\n\n  var x = thisEnd - thisStart\n  var y = end - start\n  var len = Math.min(x, y)\n\n  var thisCopy = this.slice(thisStart, thisEnd)\n  var targetCopy = target.slice(start, end)\n\n  for (var i = 0; i < len; ++i) {\n    if (thisCopy[i] !== targetCopy[i]) {\n      x = thisCopy[i]\n      y = targetCopy[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n  // Empty buffer means no match\n  if (buffer.length === 0) return -1\n\n  // Normalize byteOffset\n  if (typeof byteOffset === 'string') {\n    encoding = byteOffset\n    byteOffset = 0\n  } else if (byteOffset > 0x7fffffff) {\n    byteOffset = 0x7fffffff\n  } else if (byteOffset < -0x80000000) {\n    byteOffset = -0x80000000\n  }\n  byteOffset = +byteOffset  // Coerce to Number.\n  if (isNaN(byteOffset)) {\n    // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n    byteOffset = dir ? 0 : (buffer.length - 1)\n  }\n\n  // Normalize byteOffset: negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n  if (byteOffset >= buffer.length) {\n    if (dir) return -1\n    else byteOffset = buffer.length - 1\n  } else if (byteOffset < 0) {\n    if (dir) byteOffset = 0\n    else return -1\n  }\n\n  // Normalize val\n  if (typeof val === 'string') {\n    val = Buffer.from(val, encoding)\n  }\n\n  // Finally, search either indexOf (if dir is true) or lastIndexOf\n  if (internalIsBuffer(val)) {\n    // Special case: looking for empty string/buffer always fails\n    if (val.length === 0) {\n      return -1\n    }\n    return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n  } else if (typeof val === 'number') {\n    val = val & 0xFF // Search for a byte value [0-255]\n    if (Buffer.TYPED_ARRAY_SUPPORT &&\n        typeof Uint8Array.prototype.indexOf === 'function') {\n      if (dir) {\n        return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n      } else {\n        return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n      }\n    }\n    return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n  var indexSize = 1\n  var arrLength = arr.length\n  var valLength = val.length\n\n  if (encoding !== undefined) {\n    encoding = String(encoding).toLowerCase()\n    if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n        encoding === 'utf16le' || encoding === 'utf-16le') {\n      if (arr.length < 2 || val.length < 2) {\n        return -1\n      }\n      indexSize = 2\n      arrLength /= 2\n      valLength /= 2\n      byteOffset /= 2\n    }\n  }\n\n  function read (buf, i) {\n    if (indexSize === 1) {\n      return buf[i]\n    } else {\n      return buf.readUInt16BE(i * indexSize)\n    }\n  }\n\n  var i\n  if (dir) {\n    var foundIndex = -1\n    for (i = byteOffset; i < arrLength; i++) {\n      if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n      } else {\n        if (foundIndex !== -1) i -= i - foundIndex\n        foundIndex = -1\n      }\n    }\n  } else {\n    if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n    for (i = byteOffset; i >= 0; i--) {\n      var found = true\n      for (var j = 0; j < valLength; j++) {\n        if (read(arr, i + j) !== read(val, j)) {\n          found = false\n          break\n        }\n      }\n      if (found) return i\n    }\n  }\n\n  return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n  return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; ++i) {\n    var parsed = parseInt(string.substr(i * 2, 2), 16)\n    if (isNaN(parsed)) return i\n    buf[offset + i] = parsed\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n  return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n  // Buffer#write(string)\n  if (offset === undefined) {\n    encoding = 'utf8'\n    length = this.length\n    offset = 0\n  // Buffer#write(string, encoding)\n  } else if (length === undefined && typeof offset === 'string') {\n    encoding = offset\n    length = this.length\n    offset = 0\n  // Buffer#write(string, offset[, length][, encoding])\n  } else if (isFinite(offset)) {\n    offset = offset | 0\n    if (isFinite(length)) {\n      length = length | 0\n      if (encoding === undefined) encoding = 'utf8'\n    } else {\n      encoding = length\n      length = undefined\n    }\n  // legacy write(string, encoding, offset, length) - remove in v0.13\n  } else {\n    throw new Error(\n      'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n    )\n  }\n\n  var remaining = this.length - offset\n  if (length === undefined || length > remaining) length = remaining\n\n  if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n    throw new RangeError('Attempt to write outside buffer bounds')\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'hex':\n        return hexWrite(this, string, offset, length)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Write(this, string, offset, length)\n\n      case 'ascii':\n        return asciiWrite(this, string, offset, length)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Write(this, string, offset, length)\n\n      case 'base64':\n        // Warning: maxLength not taken into account in base64Write\n        return base64Write(this, string, offset, length)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return ucs2Write(this, string, offset, length)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  end = Math.min(buf.length, end)\n  var res = []\n\n  var i = start\n  while (i < end) {\n    var firstByte = buf[i]\n    var codePoint = null\n    var bytesPerSequence = (firstByte > 0xEF) ? 4\n      : (firstByte > 0xDF) ? 3\n      : (firstByte > 0xBF) ? 2\n      : 1\n\n    if (i + bytesPerSequence <= end) {\n      var secondByte, thirdByte, fourthByte, tempCodePoint\n\n      switch (bytesPerSequence) {\n        case 1:\n          if (firstByte < 0x80) {\n            codePoint = firstByte\n          }\n          break\n        case 2:\n          secondByte = buf[i + 1]\n          if ((secondByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n            if (tempCodePoint > 0x7F) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 3:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n            if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 4:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          fourthByte = buf[i + 3]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n            if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n              codePoint = tempCodePoint\n            }\n          }\n      }\n    }\n\n    if (codePoint === null) {\n      // we did not generate a valid codePoint so insert a\n      // replacement char (U+FFFD) and advance only 1 byte\n      codePoint = 0xFFFD\n      bytesPerSequence = 1\n    } else if (codePoint > 0xFFFF) {\n      // encode to utf16 (surrogate pair dance)\n      codePoint -= 0x10000\n      res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n      codePoint = 0xDC00 | codePoint & 0x3FF\n    }\n\n    res.push(codePoint)\n    i += bytesPerSequence\n  }\n\n  return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n  var len = codePoints.length\n  if (len <= MAX_ARGUMENTS_LENGTH) {\n    return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n  }\n\n  // Decode in chunks to avoid \"call stack size exceeded\".\n  var res = ''\n  var i = 0\n  while (i < len) {\n    res += String.fromCharCode.apply(\n      String,\n      codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n    )\n  }\n  return res\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i] & 0x7F)\n  }\n  return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; ++i) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len\n    if (start < 0) start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0) end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start) end = start\n\n  var newBuf\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    newBuf = this.subarray(start, end)\n    newBuf.__proto__ = Buffer.prototype\n  } else {\n    var sliceLen = end - start\n    newBuf = new Buffer(sliceLen, undefined)\n    for (var i = 0; i < sliceLen; ++i) {\n      newBuf[i] = this[i + start]\n    }\n  }\n\n  return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n  if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    checkOffset(offset, byteLength, this.length)\n  }\n\n  var val = this[offset + --byteLength]\n  var mul = 1\n  while (byteLength > 0 && (mul *= 0x100)) {\n    val += this[offset + --byteLength] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n    ((this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var i = byteLength\n  var mul = 1\n  var val = this[offset + --i]\n  while (i > 0 && (mul *= 0x100)) {\n    val += this[offset + --i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80)) return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n    (this[offset + 1] << 8) |\n    (this[offset + 2] << 16) |\n    (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n    (this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!internalIsBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n  if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var mul = 1\n  var i = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n    buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n      (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffffffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n    buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset + 3] = (value >>> 24)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 1] = (value >>> 8)\n    this[offset] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = 0\n  var mul = 1\n  var sub = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  var sub = 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n  if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (targetStart >= target.length) targetStart = target.length\n  if (!targetStart) targetStart = 0\n  if (end > 0 && end < start) end = start\n\n  // Copy 0 bytes; we're done\n  if (end === start) return 0\n  if (target.length === 0 || this.length === 0) return 0\n\n  // Fatal error conditions\n  if (targetStart < 0) {\n    throw new RangeError('targetStart out of bounds')\n  }\n  if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n  if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length) end = this.length\n  if (target.length - targetStart < end - start) {\n    end = target.length - targetStart + start\n  }\n\n  var len = end - start\n  var i\n\n  if (this === target && start < targetStart && targetStart < end) {\n    // descending copy from end\n    for (i = len - 1; i >= 0; --i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    // ascending copy from start\n    for (i = 0; i < len; ++i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    Uint8Array.prototype.set.call(\n      target,\n      this.subarray(start, start + len),\n      targetStart\n    )\n  }\n\n  return len\n}\n\n// Usage:\n//    buffer.fill(number[, offset[, end]])\n//    buffer.fill(buffer[, offset[, end]])\n//    buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n  // Handle string cases:\n  if (typeof val === 'string') {\n    if (typeof start === 'string') {\n      encoding = start\n      start = 0\n      end = this.length\n    } else if (typeof end === 'string') {\n      encoding = end\n      end = this.length\n    }\n    if (val.length === 1) {\n      var code = val.charCodeAt(0)\n      if (code < 256) {\n        val = code\n      }\n    }\n    if (encoding !== undefined && typeof encoding !== 'string') {\n      throw new TypeError('encoding must be a string')\n    }\n    if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n      throw new TypeError('Unknown encoding: ' + encoding)\n    }\n  } else if (typeof val === 'number') {\n    val = val & 255\n  }\n\n  // Invalid ranges are not set to a default, so can range check early.\n  if (start < 0 || this.length < start || this.length < end) {\n    throw new RangeError('Out of range index')\n  }\n\n  if (end <= start) {\n    return this\n  }\n\n  start = start >>> 0\n  end = end === undefined ? this.length : end >>> 0\n\n  if (!val) val = 0\n\n  var i\n  if (typeof val === 'number') {\n    for (i = start; i < end; ++i) {\n      this[i] = val\n    }\n  } else {\n    var bytes = internalIsBuffer(val)\n      ? val\n      : utf8ToBytes(new Buffer(val, encoding).toString())\n    var len = bytes.length\n    for (i = 0; i < end - start; ++i) {\n      this[i + start] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n  // Node converts strings with length < 2 to ''\n  if (str.length < 2) return ''\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n  units = units || Infinity\n  var codePoint\n  var length = string.length\n  var leadSurrogate = null\n  var bytes = []\n\n  for (var i = 0; i < length; ++i) {\n    codePoint = string.charCodeAt(i)\n\n    // is surrogate component\n    if (codePoint > 0xD7FF && codePoint < 0xE000) {\n      // last char was a lead\n      if (!leadSurrogate) {\n        // no lead yet\n        if (codePoint > 0xDBFF) {\n          // unexpected trail\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        } else if (i + 1 === length) {\n          // unpaired lead\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        }\n\n        // valid lead\n        leadSurrogate = codePoint\n\n        continue\n      }\n\n      // 2 leads in a row\n      if (codePoint < 0xDC00) {\n        if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n        leadSurrogate = codePoint\n        continue\n      }\n\n      // valid surrogate pair\n      codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n    } else if (leadSurrogate) {\n      // valid bmp char, but last char was a lead\n      if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n    }\n\n    leadSurrogate = null\n\n    // encode utf8\n    if (codePoint < 0x80) {\n      if ((units -= 1) < 0) break\n      bytes.push(codePoint)\n    } else if (codePoint < 0x800) {\n      if ((units -= 2) < 0) break\n      bytes.push(\n        codePoint >> 0x6 | 0xC0,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x10000) {\n      if ((units -= 3) < 0) break\n      bytes.push(\n        codePoint >> 0xC | 0xE0,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x110000) {\n      if ((units -= 4) < 0) break\n      bytes.push(\n        codePoint >> 0x12 | 0xF0,\n        codePoint >> 0xC & 0x3F | 0x80,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else {\n      throw new Error('Invalid code point')\n    }\n  }\n\n  return bytes\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    if ((units -= 2) < 0) break\n\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  for (var i = 0; i < length; ++i) {\n    if ((i + offset >= dst.length) || (i >= src.length)) break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\nfunction isnan (val) {\n  return val !== val // eslint-disable-line no-self-compare\n}\n\n\n// the following is from is-buffer, also by Feross Aboukhadijeh and with same lisence\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nexport function isBuffer(obj) {\n  return obj != null && (!!obj._isBuffer || isFastBuffer(obj) || isSlowBuffer(obj))\n}\n\nfunction isFastBuffer (obj) {\n  return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n  return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isFastBuffer(obj.slice(0, 0))\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nimport {Buffer} from 'buffer';\nvar isBufferEncoding = Buffer.isEncoding\n  || function(encoding) {\n       switch (encoding && encoding.toLowerCase()) {\n         case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true;\n         default: return false;\n       }\n     }\n\n\nfunction assertEncoding(encoding) {\n  if (encoding && !isBufferEncoding(encoding)) {\n    throw new Error('Unknown encoding: ' + encoding);\n  }\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters. CESU-8 is handled as part of the UTF-8 encoding.\n//\n// @TODO Handling all encodings inside a single object makes it very difficult\n// to reason about this code, so it should be split up in the future.\n// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code\n// points as used by CESU-8.\nexport function StringDecoder(encoding) {\n  this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, '');\n  assertEncoding(encoding);\n  switch (this.encoding) {\n    case 'utf8':\n      // CESU-8 represents each of Surrogate Pair by 3-bytes\n      this.surrogateSize = 3;\n      break;\n    case 'ucs2':\n    case 'utf16le':\n      // UTF-16 represents each of Surrogate Pair by 2-bytes\n      this.surrogateSize = 2;\n      this.detectIncompleteChar = utf16DetectIncompleteChar;\n      break;\n    case 'base64':\n      // Base-64 stores 3 bytes in 4 chars, and pads the remainder.\n      this.surrogateSize = 3;\n      this.detectIncompleteChar = base64DetectIncompleteChar;\n      break;\n    default:\n      this.write = passThroughWrite;\n      return;\n  }\n\n  // Enough space to store all bytes of a single character. UTF-8 needs 4\n  // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate).\n  this.charBuffer = new Buffer(6);\n  // Number of bytes received for the current incomplete multi-byte character.\n  this.charReceived = 0;\n  // Number of bytes expected for the current incomplete multi-byte character.\n  this.charLength = 0;\n};\n\n\n// write decodes the given buffer and returns it as JS string that is\n// guaranteed to not contain any partial multi-byte characters. Any partial\n// character found at the end of the buffer is buffered up, and will be\n// returned when calling write again with the remaining bytes.\n//\n// Note: Converting a Buffer containing an orphan surrogate to a String\n// currently works, but converting a String to a Buffer (via `new Buffer`, or\n// Buffer#write) will replace incomplete surrogates with the unicode\n// replacement character. See https://codereview.chromium.org/121173009/ .\nStringDecoder.prototype.write = function(buffer) {\n  var charStr = '';\n  // if our last write ended with an incomplete multibyte character\n  while (this.charLength) {\n    // determine how many remaining bytes this buffer has to offer for this char\n    var available = (buffer.length >= this.charLength - this.charReceived) ?\n        this.charLength - this.charReceived :\n        buffer.length;\n\n    // add the new bytes to the char buffer\n    buffer.copy(this.charBuffer, this.charReceived, 0, available);\n    this.charReceived += available;\n\n    if (this.charReceived < this.charLength) {\n      // still not enough chars in this buffer? wait for more ...\n      return '';\n    }\n\n    // remove bytes belonging to the current character from the buffer\n    buffer = buffer.slice(available, buffer.length);\n\n    // get the character that was split\n    charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding);\n\n    // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n    var charCode = charStr.charCodeAt(charStr.length - 1);\n    if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n      this.charLength += this.surrogateSize;\n      charStr = '';\n      continue;\n    }\n    this.charReceived = this.charLength = 0;\n\n    // if there are no more bytes in this buffer, just emit our char\n    if (buffer.length === 0) {\n      return charStr;\n    }\n    break;\n  }\n\n  // determine and set charLength / charReceived\n  this.detectIncompleteChar(buffer);\n\n  var end = buffer.length;\n  if (this.charLength) {\n    // buffer the incomplete character bytes we got\n    buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end);\n    end -= this.charReceived;\n  }\n\n  charStr += buffer.toString(this.encoding, 0, end);\n\n  var end = charStr.length - 1;\n  var charCode = charStr.charCodeAt(end);\n  // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n  if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n    var size = this.surrogateSize;\n    this.charLength += size;\n    this.charReceived += size;\n    this.charBuffer.copy(this.charBuffer, size, 0, size);\n    buffer.copy(this.charBuffer, 0, 0, size);\n    return charStr.substring(0, end);\n  }\n\n  // or just emit the charStr\n  return charStr;\n};\n\n// detectIncompleteChar determines if there is an incomplete UTF-8 character at\n// the end of the given buffer. If so, it sets this.charLength to the byte\n// length that character, and sets this.charReceived to the number of bytes\n// that are available for this character.\nStringDecoder.prototype.detectIncompleteChar = function(buffer) {\n  // determine how many bytes we have to check at the end of this buffer\n  var i = (buffer.length >= 3) ? 3 : buffer.length;\n\n  // Figure out if one of the last i bytes of our buffer announces an\n  // incomplete char.\n  for (; i > 0; i--) {\n    var c = buffer[buffer.length - i];\n\n    // See http://en.wikipedia.org/wiki/UTF-8#Description\n\n    // 110XXXXX\n    if (i == 1 && c >> 5 == 0x06) {\n      this.charLength = 2;\n      break;\n    }\n\n    // 1110XXXX\n    if (i <= 2 && c >> 4 == 0x0E) {\n      this.charLength = 3;\n      break;\n    }\n\n    // 11110XXX\n    if (i <= 3 && c >> 3 == 0x1E) {\n      this.charLength = 4;\n      break;\n    }\n  }\n  this.charReceived = i;\n};\n\nStringDecoder.prototype.end = function(buffer) {\n  var res = '';\n  if (buffer && buffer.length)\n    res = this.write(buffer);\n\n  if (this.charReceived) {\n    var cr = this.charReceived;\n    var buf = this.charBuffer;\n    var enc = this.encoding;\n    res += buf.slice(0, cr).toString(enc);\n  }\n\n  return res;\n};\n\nfunction passThroughWrite(buffer) {\n  return buffer.toString(this.encoding);\n}\n\nfunction utf16DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 2;\n  this.charLength = this.charReceived ? 2 : 0;\n}\n\nfunction base64DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 3;\n  this.charLength = this.charReceived ? 3 : 0;\n}\n","import {generateSchema} from \"./indexSchemaCreator\";\nimport { has, isString, difference, find } from \"lodash/fp\";\nimport { Buffer } from \"safe-buffer\";\nimport {StringDecoder} from \"string_decoder\";\nimport {getType} from \"../types\";\nimport { isSomething } from \"../common\";\n\nexport const BUFFER_MAX_BYTES = 524288; // 0.5Mb\n\nexport const CONTINUE_READING_RECORDS = \"CONTINUE_READING\";\nexport const READ_REMAINING_TEXT = \"READ_REMAINING\";\nexport const CANCEL_READ = \"CANCEL\";\n\nexport const getIndexWriter = (hierarchy, indexNode, readableStream, writableStream, end) => {\n    const schema = generateSchema(hierarchy, indexNode);\n\n    return ({\n        read: read(readableStream, schema),\n        updateIndex: updateIndex(readableStream, writableStream, schema, end)\n    });\n};\n\nexport const getIndexReader = (hierarchy, indexNode, readableStream) => \n    read(\n        readableStream, \n        generateSchema(hierarchy, indexNode)\n    );\n\nconst updateIndex = (readableStream, writableStream, schema) => async (itemsToWrite, keysToRemove) => {\n    const write = newOutputWriter(BUFFER_MAX_BYTES, writableStream);\n    const writtenItems = []; \n    await read(readableStream, schema)(\n        async indexedItem => {\n            const updated = find(i => indexedItem.key === i.key)(itemsToWrite);\n            const removed = find(k => indexedItem.key === k)(keysToRemove);\n            \n            if(isSomething(removed)) \n                return CONTINUE_READING_RECORDS;\n\n            if(isSomething(updated)) {\n                const serializedItem =  serializeItem(schema, updated);\n                await write(serializedItem);\n                writtenItems.push(updated);\n            } else {\n                await write(\n                    serializeItem(schema, indexedItem)\n                );\n            } \n\n            return CONTINUE_READING_RECORDS;\n\n        },\n        async text => await write(text)\n    );\n\n    if(writtenItems.length !== itemsToWrite.length) {\n        const toAdd = difference(itemsToWrite, writtenItems);\n        for(let added of toAdd) {\n            await write(\n                serializeItem(schema, added)\n            );\n        }\n    } else if(writtenItems.length === 0) {\n        // potentially are no records\n        await write(\"\");\n    }\n\n    await write();\n    await writableStream.end();\n};\n\nconst read = (readableStream, schema) => async (onGetItem, onGetText) => {\n    const readInput = newInputReader(readableStream);\n    let text = await readInput();\n    let status = CONTINUE_READING_RECORDS;\n    while(text.length > 0) {\n\n        if(status === READ_REMAINING_TEXT) {\n            await onGetText(text);\n            continue;\n        }\n\n        if(status === CANCEL_READ) {\n            return;\n        }\n\n        let rowText = \"\";\n        let currentCharIndex=0;\n        for(let currentChar of text) {\n            rowText += currentChar;\n            if(currentChar === \"\\r\") {\n                status = await onGetItem(\n                    deserializeRow(schema, rowText)\n                );\n                rowText = \"\";\n                if(status === READ_REMAINING_TEXT) {\n                    break;\n                }\n            }\n            currentCharIndex++;\n        }\n\n        if(currentCharIndex < text.length -1) {\n            await onGetText(text.substring(currentCharIndex + 1));\n        }\n\n        text = await readInput();\n    }\n\n    await readableStream.destroy();\n\n};\n\nconst newOutputWriter = (flushBoundary, writableStream) => {\n    \n    let currentBuffer = null;\n\n    return async (text) => {\n\n        if(isString(text) && currentBuffer === null)\n            currentBuffer = Buffer.from(text, \"utf8\");\n        else if(isString(text))\n            currentBuffer = Buffer.concat([\n                currentBuffer,\n                Buffer.from(text, \"utf8\")\n            ]);\n        \n        if(currentBuffer !== null &&\n            (currentBuffer.length > flushBoundary\n             || !isString(text))) {\n\n            await writableStream.write(currentBuffer);\n            currentBuffer = null;\n        }\n    }\n};\n\nconst newInputReader = (readableStream) => {\n\n    const decoder = new StringDecoder('utf8');\n    let remainingBytes = [];\n\n    return async () => {\n\n        let nextBytesBuffer = await readableStream.read(BUFFER_MAX_BYTES);\n        const remainingBuffer = Buffer.from(remainingBytes);\n\n        if(!nextBytesBuffer) nextBytesBuffer = Buffer.from([]);\n\n        const moreToRead = nextBytesBuffer.length === BUFFER_MAX_BYTES;\n\n        const buffer = Buffer.concat(\n            [remainingBuffer, nextBytesBuffer],\n            remainingBuffer.length + nextBytesBuffer.length);\n\n        const text = decoder.write(buffer);\n        remainingBytes = decoder.end(buffer);\n\n        if(!moreToRead && remainingBytes.length > 0) {\n            // if for any reason, we have remaining bytes at the end\n            // of the stream, just discard - dont see why this should\n            // ever happen, but if it does, it could cause a stack overflow\n            remainingBytes = [];\n        }\n\n        return text;\n    };\n};\n\nconst deserializeRow = (schema, rowText) => {\n    let currentPropIndex = 0;\n    let currentCharIndex = 0;\n    let currentValueText = \"\";\n    let isEscaped = false;\n    const item = {};\n\n    const setCurrentProp = () => {\n        const currentProp = schema[currentPropIndex];\n        const type = getType(currentProp.type);\n        const value = currentValueText === \"\"\n                      ? type.getDefaultValue()\n                      : type.safeParseValue(\n                          currentValueText);\n        item[currentProp.name] = value;\n    };\n    \n    while(currentPropIndex < schema.length) {\n\n        if(currentCharIndex < rowText.length) {\n            const currentChar = rowText[currentCharIndex];\n            if(isEscaped) {\n                if(currentChar === \"r\") {\n                    currentValueText += \"\\r\";\n                } else {\n                    currentValueText += currentChar;\n                }\n                isEscaped = false;\n            } else {\n                if(currentChar === \",\") {\n                    setCurrentProp();\n                    currentValueText = \"\";\n                    currentPropIndex++;\n                } else if(currentChar === \"\\\\\") {\n                    isEscaped = true;\n                } else {\n                    currentValueText += currentChar;\n                }\n            }\n            currentCharIndex++; \n        } else {\n            currentValueText = \"\";\n            setCurrentProp();\n            currentPropIndex++;\n        }\n    }\n\n    return item;\n};\n\nexport const serializeItem = (schema, item)  => {\n\n    let rowText = \"\"\n\n    for(let prop of schema) {\n        const type = getType(prop.type);\n        const value = has(prop.name)(item)\n                      ? item[prop.name]\n                      : type.getDefaultValue()\n        \n        const valStr = type.stringify(value);\n\n        for(let i = 0; i < valStr.length; i++) {\n            const currentChar = valStr[i];\n            if(currentChar === \",\" \n               || currentChar === \"\\r\" \n               || currentChar === \"\\\\\") {\n                rowText += \"\\\\\";\n            }\n\n            if(currentChar === \"\\r\") {\n                rowText += \"r\";\n            } else {\n                rowText += currentChar;\n            }\n        }\n\n        rowText += \",\";\n    }\n\n    rowText += \"\\r\";\n    return rowText;\n};","import lunr from 'lunr';\nimport {promiseReadableStream} from \"./promiseReadableStream\";\nimport { createIndexFile } from './sharding';\nimport { generateSchema } from './indexSchemaCreator';\nimport { getIndexReader, CONTINUE_READING_RECORDS } from './serializer';\n\nexport const readIndex = async (hierarchy, datastore, index, indexedDataKey) => {\n  const records = [];\n  const doRead = iterateIndex(\n        async item => {\n      records.push(item);\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => records\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\nexport const searchIndex = async (hierarchy, datastore, index, indexedDataKey, searchPhrase) => {\n  const records = [];\n  const schema = generateSchema(hierarchy, index);\n  const doRead = iterateIndex(\n        async item => {\n      const idx = lunr(function () {\n        this.ref('key');\n        for (const field of schema) {\n          this.field(field.name);\n        }\n        this.add(item);\n      });\n      const searchResults = idx.search(searchPhrase);\n      if (searchResults.length === 1) {\n        item._searchResult = searchResults[0];\n        records.push(item);\n      }\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => records\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\nexport const iterateIndex = (onGetItem, getFinalResult) => async (hierarchy, datastore, index, indexedDataKey) => {\n  try {\n    const readableStream = promiseReadableStream(\n        await datastore.readableFileStream(indexedDataKey)\n    );\n\n    const read = getIndexReader(hierarchy, index, readableStream);\n    await read(onGetItem);\n    return getFinalResult();\n  } catch (e) {\n    if (await datastore.exists(indexedDataKey)) {\n      throw e;\n    } else {\n      await createIndexFile(\n        datastore,\n        indexedDataKey,\n        index,\n      );\n    }\n    return [];\n  }\n};\n","import { getRecordInfo } from \"../recordApi/recordInfo\";\nimport { \n    getParentKey, getLastPartInKey\n} from \"../templateApi/hierarchy\";\nimport { keySep } from \"../common\";\n\nexport const getIndexDir = (hierarchy, indexKey) => {\n\n    const parentKey = getParentKey(indexKey);\n\n    if(parentKey === \"\") return indexKey;\n    if(parentKey === keySep) return indexKey;\n\n    const recordInfo = getRecordInfo(\n        hierarchy, \n        parentKey);\n        \n    return recordInfo.child(\n        getLastPartInKey(indexKey));\n}","import { flatten, merge } from 'lodash/fp';\nimport {\n  safeKey, apiWrapper, $,\n  events, isNonEmptyString,\n} from '../common';\nimport { readIndex, searchIndex } from '../indexing/read';\nimport {\n  getUnshardedIndexDataKey,\n  getShardKeysInRange,\n} from '../indexing/sharding';\nimport {\n  getExactNodeForKey, isIndex,\n  isShardedIndex,\n} from '../templateApi/hierarchy';\nimport { permission } from '../authApi/permissions';\nimport { getIndexDir } from \"./getIndexDir\";\n\nexport const listItems = app => async (indexKey, options) => {\n  indexKey = safeKey(indexKey);\n  return apiWrapper(\n    app,\n    events.indexApi.listItems,\n    permission.readIndex.isAuthorized(indexKey),\n    { indexKey, options },\n    _listItems, app, indexKey, options,\n  );\n}\n\nconst defaultOptions = { rangeStartParams: null, rangeEndParams: null, searchPhrase: null };\n\nconst _listItems = async (app, indexKey, options = defaultOptions) => {\n  const { searchPhrase, rangeStartParams, rangeEndParams } = $({}, [\n    merge(options),\n    merge(defaultOptions),\n  ]);\n\n  const getItems = async indexedDataKey => (isNonEmptyString(searchPhrase)\n    ? await searchIndex(\n      app.hierarchy,\n      app.datastore,\n      indexNode,\n      indexedDataKey,\n      searchPhrase,\n    )\n    : await readIndex(\n      app.hierarchy,\n      app.datastore,\n      indexNode,\n      indexedDataKey,\n    ));\n\n  indexKey = safeKey(indexKey);\n  const indexNode = getExactNodeForKey(app.hierarchy)(indexKey);\n  const indexDir = getIndexDir(app.hierarchy, indexKey);\n\n  if (!isIndex(indexNode)) { throw new Error('supplied key is not an index'); }\n\n  if (isShardedIndex(indexNode)) {\n    const shardKeys = await getShardKeysInRange(\n      app, indexNode, indexDir, rangeStartParams, rangeEndParams,\n    );\n    const items = [];\n    for (const k of shardKeys) {\n      items.push(await getItems(k));\n    }\n    return flatten(items);\n  }\n  return await getItems(\n    getUnshardedIndexDataKey(indexDir),\n  );\n};\n","import { map, isString, has, some } from 'lodash/fp';\nimport {\n  getExactNodeForKey,\n  findField, getNode, isGlobalIndex,\n} from '../templateApi/hierarchy';\nimport { listItems } from '../indexApi/listItems';\nimport {\n  $, apiWrapperSync, events, safeKey\n} from '../common';\nimport { getIndexKey_BasedOnDecendant } from '../indexing/sharding';\nimport { permission } from '../authApi/permissions';\n\nexport const getContext = app => recordKey => {\n  recordKey = safeKey(recordKey);\n  return  apiWrapperSync(\n    app,\n    events.recordApi.getContext,\n    permission.readRecord.isAuthorized(recordKey),\n    { recordKey },\n    _getContext, app, recordKey,\n  );\n}\n\nexport const _getContext = (app, recordKey) => {\n  recordKey = safeKey(recordKey);\n  const recordNode = getExactNodeForKey(app.hierarchy)(recordKey);\n\n  const cachedReferenceIndexes = {};\n\n  const lazyLoadReferenceIndex = async (typeOptions) => {\n    if (!has(typeOptions.indexNodeKey)(cachedReferenceIndexes)) {\n      cachedReferenceIndexes[typeOptions.indexNodeKey] = {\n        typeOptions,\n        data: await readReferenceIndex(\n          app, recordKey, typeOptions,\n        ),\n      };\n    }\n\n    return cachedReferenceIndexes[typeOptions.indexNodeKey];\n  };\n\n  const getTypeOptions = typeOptions_or_fieldName => (isString(typeOptions_or_fieldName)\n    ? findField(recordNode, typeOptions_or_fieldName)\n      .typeOptions\n    : typeOptions_or_fieldName);\n\n  return {\n    referenceExists: async (typeOptions_or_fieldName, key) => {\n      const typeOptions = getTypeOptions(typeOptions_or_fieldName);\n      const { data } = await lazyLoadReferenceIndex(typeOptions);\n      return some(i => i.key === key)(data);\n    },\n    referenceOptions: async (typeOptions_or_fieldName) => {\n      const typeOptions = getTypeOptions(typeOptions_or_fieldName);\n      const { data } = await lazyLoadReferenceIndex(typeOptions);\n      return data;\n    },\n    recordNode,\n  };\n};\n\nconst readReferenceIndex = async (app, recordKey, typeOptions) => {\n  const indexNode = getNode(app.hierarchy, typeOptions.indexNodeKey);\n  const indexKey = isGlobalIndex(indexNode)\n    ? indexNode.nodeKey()\n    : getIndexKey_BasedOnDecendant(\n      recordKey, indexNode,\n    );\n\n  const items = await listItems(app)(indexKey);\n  return $(items, [\n    map(i => ({\n      key: i.key,\n      value: i[typeOptions.displayValue],\n    })),\n  ]);\n};\n","import {\n  map, reduce, filter,\n  isEmpty, flatten, each,\n} from 'lodash/fp';\nimport { compileExpression } from '@nx-js/compiler-util';\nimport _ from 'lodash';\nimport { getExactNodeForKey } from '../templateApi/hierarchy';\nimport { validateFieldParse, validateTypeConstraints } from '../types';\nimport { $, isNothing, isNonEmptyString } from '../common';\nimport { _getContext } from './getContext';\n\nconst fieldParseError = (fieldName, value) => ({\n  fields: [fieldName],\n  message: `Could not parse field ${fieldName}:${value}`,\n});\n\nconst validateAllFieldParse = (record, recordNode) => $(recordNode.fields, [\n  map(f => ({ name: f.name, parseResult: validateFieldParse(f, record) })),\n  reduce((errors, f) => {\n    if (f.parseResult.success) return errors;\n    errors.push(\n      fieldParseError(f.name, f.parseResult.value),\n    );\n    return errors;\n  }, []),\n]);\n\nconst validateAllTypeConstraints = async (record, recordNode, context) => {\n  const errors = [];\n  for (const field of recordNode.fields) {\n    $(await validateTypeConstraints(field, record, context), [\n      filter(isNonEmptyString),\n      map(m => ({ message: m, fields: [field.name] })),\n      each(e => errors.push(e)),\n    ]);\n  }\n  return errors;\n};\n\nconst runRecordValidationRules = (record, recordNode) => {\n  const runValidationRule = (rule) => {\n    const isValid = compileExpression(rule.expressionWhenValid);\n    const expressionContext = { record, _ };\n    return (isValid(expressionContext)\n      ? { valid: true }\n      : ({\n        valid: false,\n        fields: rule.invalidFields,\n        message: rule.messageWhenInvalid,\n      }));\n  };\n\n  return $(recordNode.validationRules, [\n    map(runValidationRule),\n    flatten,\n    filter(r => r.valid === false),\n    map(r => ({ fields: r.fields, message: r.message })),\n  ]);\n};\n\nexport const validate = app => async (record, context) => {\n  context = isNothing(context)\n    ? _getContext(app, record.key)\n    : context;\n\n  const recordNode = getExactNodeForKey(app.hierarchy)(record.key);\n  const fieldParseFails = validateAllFieldParse(record, recordNode);\n\n  // non parsing would cause further issues - exit here\n  if (!isEmpty(fieldParseFails)) { return ({ isValid: false, errors: fieldParseFails }); }\n\n  const recordValidationRuleFails = runRecordValidationRules(record, recordNode);\n  const typeContraintFails = await validateAllTypeConstraints(record, recordNode, context);\n\n  if (isEmpty(fieldParseFails)\n       && isEmpty(recordValidationRuleFails)\n       && isEmpty(typeContraintFails)) {\n    return ({ isValid: true, errors: [] });\n  }\n\n  return ({\n    isValid: false,\n    errors: _.union(fieldParseFails, typeContraintFails, recordValidationRuleFails),\n  });\n};\n","import { filter } from 'lodash/fp';\nimport {\n  getFlattenedHierarchy,\n  isCollectionRecord,\n  isRoot,\n} from '../templateApi/hierarchy';\nimport { $, allTrue, joinKey } from '../common';\n\nconst ensureCollectionIsInitialised = async (datastore, node, dir) => {\n  if (!await datastore.exists(dir)) {\n    await datastore.createFolder(dir);\n    await datastore.createFolder(joinKey(dir, node.nodeId));\n  }\n};\n\nexport const initialiseRootCollections = async (datastore, hierarchy) => {\n  const rootCollectionRecord = allTrue(\n    n => isRoot(n.parent()),\n    isCollectionRecord,\n  );\n\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n\n  const collectionRecords = $(flathierarchy, [\n    filter(rootCollectionRecord),\n  ]);\n\n  for (const col of collectionRecords) {\n    await ensureCollectionIsInitialised(\n      datastore,\n      col,\n      col.collectionPathRegx()\n    );\n  }\n};\n\nexport const initialiseChildCollections = async (app, recordInfo) => {\n  const childCollectionRecords = $(recordInfo.recordNode, [\n    n => n.children,\n    filter(isCollectionRecord),\n  ]);\n\n  for (const child of childCollectionRecords) {\n    await ensureCollectionIsInitialised(\n      app.datastore,\n      child,\n      recordInfo.child(child.collectionName),\n    );\n  }\n};\n","import {\n  joinKey, keySep, getHashCode,\n} from '../common';\nimport { getLastPartInKey } from '../templateApi/hierarchy';\n\nexport const TRANSACTIONS_FOLDER = `${keySep}.transactions`;\nexport const LOCK_FILENAME = 'lock';\nexport const LOCK_FILE_KEY = joinKey(\n  TRANSACTIONS_FOLDER, LOCK_FILENAME,\n);\nexport const idSep = '$';\n\nconst isOfType = typ => trans => trans.transactionType === typ;\n\nexport const CREATE_RECORD_TRANSACTION = 'create';\nexport const UPDATE_RECORD_TRANSACTION = 'update';\nexport const DELETE_RECORD_TRANSACTION = 'delete';\nexport const BUILD_INDEX_TRANSACTION = 'build';\n\nexport const isUpdate = isOfType(UPDATE_RECORD_TRANSACTION);\nexport const isDelete = isOfType(DELETE_RECORD_TRANSACTION);\nexport const isCreate = isOfType(CREATE_RECORD_TRANSACTION);\nexport const isBuildIndex = isOfType(BUILD_INDEX_TRANSACTION);\n\nexport const keyToFolderName = nodeKey => getHashCode(nodeKey);\n\nexport const getTransactionId = (recordId, transactionType, uniqueId) => \n  `${recordId}${idSep}${transactionType}${idSep}${uniqueId}`;\n\nexport const buildIndexFolder = '.BUILD-';\nexport const nodeKeyHashFromBuildFolder = folder => folder.replace(buildIndexFolder, '');\n\nexport const isBuildIndexFolder = key => getLastPartInKey(key).startsWith(buildIndexFolder);\n\nexport const IndexNodeKeyFolder = indexNodeKey => joinKey(\n  TRANSACTIONS_FOLDER,\n  buildIndexFolder + keyToFolderName(indexNodeKey),\n);\n\nexport const IndexNodeKeyBatchFolder = (indexNodeKey, count) => \n  joinKey(IndexNodeKeyFolder(indexNodeKey), Math.floor(count / BUILDINDEX_BATCH_COUNT).toString());\n\nexport const IndexShardKeyFolder = (indexNodeKey, indexShardKey) => \n  joinKey(IndexNodeKeyFolder(indexNodeKey), indexShardKey);\n\nexport const BUILDINDEX_BATCH_COUNT = 1000;\nexport const timeoutMilliseconds = 30 * 1000; // 30 secs\nexport const maxLockRetries = 1;\n","import { generate } from 'shortid';\nimport { joinKey } from '../common';\nimport { getLastPartInKey } from '../templateApi/hierarchy';\nimport {\n  IndexNodeKeyFolder, BUILDINDEX_BATCH_COUNT,\n  IndexNodeKeyBatchFolder, TRANSACTIONS_FOLDER, getTransactionId, CREATE_RECORD_TRANSACTION, UPDATE_RECORD_TRANSACTION,\n  DELETE_RECORD_TRANSACTION, BUILD_INDEX_TRANSACTION,\n} from './transactionsCommon';\n\n\nexport const transactionForCreateRecord = async (app, record) => await transaction(\n  app.datastore, CREATE_RECORD_TRANSACTION,\n  record.key, { record },\n  getTransactionKey_Records,\n);\n\nexport const transactionForUpdateRecord = async (app, oldRecord, newRecord) => await transaction(\n  app.datastore, UPDATE_RECORD_TRANSACTION,\n  newRecord.key, { oldRecord, record: newRecord },\n  getTransactionKey_Records,\n);\n\nexport const transactionForDeleteRecord = async (app, record) => await transaction(\n  app.datastore, DELETE_RECORD_TRANSACTION,\n  record.key, { record },\n  getTransactionKey_Records,\n);\n\nexport const transactionForBuildIndex = async (app, indexNodeKey, recordKey, count) => {\n  const transactionFolder = IndexNodeKeyBatchFolder(indexNodeKey, count);\n  if (count % BUILDINDEX_BATCH_COUNT === 0) {\n    await app.datastore.createFolder(transactionFolder);\n  }\n\n  return await transaction(\n    app.datastore, BUILD_INDEX_TRANSACTION,\n    recordKey, { recordKey },\n    id => joinKey(transactionFolder, id),\n  );\n};\n\nexport const createBuildIndexFolder = async (datastore, indexNodeKey) => await datastore.createFolder(\n  IndexNodeKeyFolder(indexNodeKey),\n);\n\nconst getTransactionKey_Records = id => joinKey(TRANSACTIONS_FOLDER, id);\n\nconst transaction = async (datastore, transactionType, recordKey, data, getTransactionKey) => {\n  const recordId = getLastPartInKey(recordKey);\n  const uniqueId = generate();\n  const id = getTransactionId(\n    recordId, transactionType, uniqueId,\n  );\n\n  const key = getTransactionKey(id);\n\n  const trans = {\n    transactionType,\n    recordKey,\n    ...data,\n    id,\n  };\n\n  await datastore.createJson(\n    key, trans,\n  );\n\n  return trans;\n};\n","import { isShardedIndex } from '../templateApi/hierarchy';\nimport { joinKey } from '../common';\nimport { getShardMapKey, getUnshardedIndexDataKey, createIndexFile } from './sharding';\n\nexport const initialiseIndex = async (datastore, dir, index) => {\n  const indexDir = joinKey(dir, index.name);\n\n  await datastore.createFolder(indexDir);\n\n  if (isShardedIndex(index)) {\n    await datastore.createFile(\n      getShardMapKey(indexDir),\n      '[]',\n    );\n  } else {\n    await createIndexFile(\n      datastore,\n      getUnshardedIndexDataKey(indexDir),\n      index,\n    );\n  }\n};\n","import {\n  cloneDeep, take, takeRight,\n  flatten, map, filter\n} from 'lodash/fp';\nimport { initialiseChildCollections } from '../collectionApi/initialise';\nimport { validate } from './validate';\nimport { _loadFromInfo } from './load';\nimport {\n  apiWrapper, events, $, joinKey,\n} from '../common';\nimport {\n  getFlattenedHierarchy, isRecord, getNode, \n  fieldReversesReferenceToNode,\n} from '../templateApi/hierarchy';\nimport {\n  transactionForCreateRecord,\n  transactionForUpdateRecord,\n} from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { initialiseIndex } from '../indexing/initialiseIndex';\nimport { BadRequestError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const save = app => async (record, context) => apiWrapper(\n  app,\n  events.recordApi.save,\n  record.isNew\n    ? permission.createRecord.isAuthorized(record.key)\n    : permission.updateRecord.isAuthorized(record.key), { record },\n  _save, app, record, context, false,\n);\n\n\nexport const _save = async (app, record, context, skipValidation = false) => {\n  const recordClone = cloneDeep(record);\n  if (!skipValidation) {\n    const validationResult = await validate(app)(recordClone, context);\n    if (!validationResult.isValid) {\n      await app.publish(events.recordApi.save.onInvalid, { record, validationResult });\n      throw new BadRequestError(`Save : Record Invalid : ${\n        JSON.stringify(validationResult.errors)}`);\n    }\n  }\n\n  const recordInfo = getRecordInfo(app.hierarchy, record.key);\n  const {\n    recordNode, pathInfo,\n    recordJson, files,\n  } = recordInfo;\n\n  if (recordClone.isNew) {\n    \n    if(!recordNode)\n      throw new Error(\"Cannot find node for \" + record.key);\n\n    const transaction = await transactionForCreateRecord(\n      app, recordClone,\n    );\n    recordClone.transactionId = transaction.id;\n    await createRecordFolderPath(app.datastore, pathInfo);\n    await app.datastore.createFolder(files);\n    await app.datastore.createJson(recordJson, recordClone);\n    await initialiseReverseReferenceIndexes(app, recordInfo);\n    await initialiseAncestorIndexes(app, recordInfo);\n    await initialiseChildCollections(app, recordInfo);\n    await app.publish(events.recordApi.save.onRecordCreated, {\n      record: recordClone,\n    });\n  } else {\n    const oldRecord = await _loadFromInfo(app, recordInfo);\n    const transaction = await transactionForUpdateRecord(\n      app, oldRecord, recordClone,\n    );\n    recordClone.transactionId = transaction.id;\n    await app.datastore.updateJson(\n      recordJson,\n      recordClone,\n    );\n    await app.publish(events.recordApi.save.onRecordUpdated, {\n      old: oldRecord,\n      new: recordClone,\n    });\n  }\n\n  await app.cleanupTransactions();\n\n  const returnedClone = cloneDeep(recordClone);\n  returnedClone.isNew = false;\n  return returnedClone;\n};\n\nconst initialiseAncestorIndexes = async (app, recordInfo) => {\n  for (const index of recordInfo.recordNode.indexes) {\n    const indexKey = recordInfo.child(index.name);\n    if (!await app.datastore.exists(indexKey)) { \n      await initialiseIndex(app.datastore, recordInfo.dir, index); \n    }\n  }\n};\n\nconst initialiseReverseReferenceIndexes = async (app, recordInfo) => {\n\n  const indexNodes = $(fieldsThatReferenceThisRecord(app, recordInfo.recordNode), [\n    map(f => $(f.typeOptions.reverseIndexNodeKeys, [\n      map(n => getNode(\n        app.hierarchy,\n        n,\n      )),\n    ])),\n    flatten,\n  ]);\n\n  for (const indexNode of indexNodes) {\n    await initialiseIndex(\n      app.datastore, recordInfo.dir, indexNode,\n    );\n  }\n};\n\nconst fieldsThatReferenceThisRecord = (app, recordNode) => $(app.hierarchy, [\n  getFlattenedHierarchy,\n  filter(isRecord),\n  map(n => n.fields),\n  flatten,\n  filter(fieldReversesReferenceToNode(recordNode)),\n]);\n\nconst createRecordFolderPath = async (datastore, pathInfo) => {\n  \n  const recursiveCreateFolder = async (subdirs, dirsThatNeedCreated=undefined) => {\n\n    // iterate backwards through directory hierachy\n    // until we get to a folder that exists, then create the rest\n    // e.g \n    // - some/folder/here\n    // - some/folder\n    // - some\n    const thisFolder = joinKey(pathInfo.base, ...subdirs);\n\n    if(await datastore.exists(thisFolder)) {\n\n      let creationFolder = thisFolder;\n      for(let nextDir of (dirsThatNeedCreated || []) ) {\n        creationFolder = joinKey(creationFolder, nextDir);\n        await datastore.createFolder(creationFolder);\n      }\n\n    } else if(!dirsThatNeedCreated || dirsThatNeedCreated.length > 0) {\n\n      dirsThatNeedCreated = !dirsThatNeedCreated\n                          ? []\n                          :dirsThatNeedCreated;\n      \n      await recursiveCreateFolder(\n        take(subdirs.length - 1)(subdirs),\n        [...takeRight(1)(subdirs), ...dirsThatNeedCreated]\n      );\n    }\n  }\n\n  await recursiveCreateFolder(pathInfo.subdirs);\n\n  return joinKey(pathInfo.base, ...pathInfo.subdirs);\n\n}","import {\n  safeKey, apiWrapper,\n  events, joinKey,\n} from '../common';\nimport { _deleteRecord } from '../recordApi/delete';\nimport { getAllIdsIterator } from '../indexing/allIds';\nimport { permission } from '../authApi/permissions';\nimport { getCollectionDir } from \"../recordApi/recordInfo\";\n\nexport const deleteCollection = (app, disableCleanup = false) => async key => apiWrapper(\n  app,\n  events.collectionApi.delete,\n  permission.manageCollection.isAuthorized,\n  { key },\n  _deleteCollection, app, key, disableCleanup,\n);\n\n/*\n  const recordNode = getCollectionNode(app.hierarchy, key);\n\n*/\n\nexport const _deleteCollection = async (app, key, disableCleanup) => {\n  key = safeKey(key);\n  const collectionDir = getCollectionDir(app.hierarchy, key);\n  await deleteRecords(app, key);\n  await deleteCollectionFolder(app, collectionDir);\n  if (!disableCleanup) { await app.cleanupTransactions(); }\n};\n\nconst deleteCollectionFolder = async (app, dir) => \n  await app.datastore.deleteFolder(dir);\n\nconst deleteRecords = async (app, key) => {\n  \n  const iterate = await getAllIdsIterator(app)(key);\n\n  let ids = await iterate();\n  while (!ids.done) {\n    if (ids.result.collectionKey === key) {\n      for (const id of ids.result.ids) {\n        await _deleteRecord(\n          app,\n          joinKey(key, id),\n          true,\n        );\n      }\n    }\n\n    ids = await iterate();\n  }\n};\n","import {\n  safeKey, apiWrapper,\n  events, joinKey,\n} from '../common';\nimport { _load } from './load';\nimport { _deleteCollection } from '../collectionApi/delete';\nimport {\n  getExactNodeForKey\n} from '../templateApi/hierarchy';\nimport { transactionForDeleteRecord } from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { getRecordInfo } from './recordInfo';\n\nexport const deleteRecord = (app, disableCleanup = false) => async key => {\n  key = safeKey(key);\n  return apiWrapper(\n    app,\n    events.recordApi.delete,\n    permission.deleteRecord.isAuthorized(key),\n    { key },\n    _deleteRecord, app, key, disableCleanup,\n  );\n}\n\n// called deleteRecord because delete is a keyword\nexport const _deleteRecord = async (app, key, disableCleanup) => {\n  const recordInfo = getRecordInfo(app.hierarchy, key);\n  key = recordInfo.key;\n  const node = getExactNodeForKey(app.hierarchy)(key);\n\n  const record = await _load(app, key);\n  await transactionForDeleteRecord(app, record);\n\n  for (const collectionRecord of node.children) {\n    const collectionKey = joinKey(\n      key, collectionRecord.collectionName,\n    );\n    await _deleteCollection(app, collectionKey, true);\n  }\n\n  await app.datastore.deleteFolder(recordInfo.dir);\n\n  if (!disableCleanup) { await app.cleanupTransactions(); }\n};\n\n","import {\n  includes, filter,\n  map, some,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { _loadFromInfo } from './load';\nimport {\n  apiWrapper, events, splitKey,\n  $, joinKey, isNothing, tryAwaitOrIgnore,\n} from '../common';\nimport { getExactNodeForKey } from '../templateApi/hierarchy';\nimport { permission } from '../authApi/permissions';\nimport { isLegalFilename } from '../types/file';\nimport { BadRequestError, ForbiddenError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const uploadFile = app => async (recordKey, readableStream, relativeFilePath) => apiWrapper(\n  app,\n  events.recordApi.uploadFile,\n  permission.updateRecord.isAuthorized(recordKey),\n  { recordKey, readableStream, relativeFilePath },\n  _uploadFile, app, recordKey, readableStream, relativeFilePath,\n);\n\nconst _uploadFile = async (app, recordKey, readableStream, relativeFilePath) => {\n  if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); }\n  if (isNothing(relativeFilePath)) { throw new BadRequestError('file path not supplied'); }\n  if (!isLegalFilename(relativeFilePath)) { throw new BadRequestError('Illegal filename'); }\n\n  const recordInfo = getRecordInfo(app.hierarchy, recordKey);\n  const record = await _loadFromInfo(app, recordInfo);\n\n  const fullFilePath = safeGetFullFilePath(\n    recordInfo.dir, relativeFilePath,\n  );\n\n  const tempFilePath = `${fullFilePath}_${generate()}.temp`;\n\n  const outputStream = await app.datastore.writableFileStream(\n    tempFilePath,\n  );\n\n  return new Promise((resolve,reject) => {\n    readableStream.pipe(outputStream);\n    outputStream.on('error', reject);\n    outputStream.on('finish', resolve);\n  })\n  .then(() => app.datastore.getFileSize(tempFilePath))\n  .then(size => {\n    const isExpectedFileSize = checkFileSizeAgainstFields(\n      app, record, relativeFilePath, size\n    );  \n    if (!isExpectedFileSize) { throw new BadRequestError(`Fields for ${relativeFilePath} do not have expected size: ${join(',')(incorrectFields)}`); }  \n\n  })\n  .then(() => tryAwaitOrIgnore(app.datastore.deleteFile, fullFilePath))\n  .then(() => app.datastore.renameFile(tempFilePath, fullFilePath));\n\n};\n\nconst checkFileSizeAgainstFields = (app, record, relativeFilePath, expectedSize) => {\n  const recordNode = getExactNodeForKey(app.hierarchy)(record.key);\n\n  const incorrectFileFields = $(recordNode.fields, [\n    filter(f => f.type === 'file'\n      && record[f.name].relativePath === relativeFilePath\n      && record[f.name].size !== expectedSize),\n    map(f => f.name),\n  ]);\n\n  const incorrectFileArrayFields = $(recordNode.fields, [\n    filter(a => a.type === 'array<file>'\n      && $(record[a.name], [\n        some(f => record[f.name].relativePath === relativeFilePath\n          && record[f.name].size !== expectedSize),\n      ])),\n    map(f => f.name),\n  ]);\n\n  const incorrectFields = [\n    ...incorrectFileFields,\n    ...incorrectFileArrayFields,\n  ];\n\n  if (incorrectFields.length > 0) {\n    return false;\n  }\n\n  return true;\n};\n\nexport const safeGetFullFilePath = (recordDir, relativeFilePath) => {\n  const naughtyUser = () => { throw new ForbiddenError('naughty naughty'); };\n\n  if (relativeFilePath.startsWith('..')) naughtyUser();\n\n  const pathParts = splitKey(relativeFilePath);\n\n  if (includes('..')(pathParts)) naughtyUser();\n\n  const recordKeyParts = splitKey(recordDir);\n\n  const fullPathParts = [\n    ...recordKeyParts,\n    'files',\n    ...filter(p => p !== '.')(pathParts),\n  ];\n\n  return joinKey(fullPathParts);\n};\n","import { apiWrapper, events, isNothing } from '../common';\nimport { permission } from '../authApi/permissions';\nimport { safeGetFullFilePath } from './uploadFile';\nimport { BadRequestError } from '../common/errors';\nimport { getRecordInfo } from \"./recordInfo\";\n\nexport const downloadFile = app => async (recordKey, relativePath) => apiWrapper(\n  app,\n  events.recordApi.uploadFile,\n  permission.readRecord.isAuthorized(recordKey),\n  { recordKey, relativePath },//remove dupe key 'recordKey' from object\n  _downloadFile, app, recordKey, relativePath,\n); \n\n\nconst _downloadFile = async (app, recordKey, relativePath) => {\n  if (isNothing(recordKey)) { throw new BadRequestError('Record Key not supplied'); }\n  if (isNothing(relativePath)) { throw new BadRequestError('file path not supplied'); }\n\n  const {dir} = getRecordInfo(app.hierarchy, recordKey);\n  return await app.datastore.readableFileStream(\n    safeGetFullFilePath(\n      dir, relativePath,\n    ),\n  );\n};\n","import { find, take, union } from 'lodash/fp';\nimport { getFlattenedHierarchy } from '../templateApi/hierarchy';\nimport { $, splitKey, joinKey } from '../common';\nimport { NotFoundError } from '../common/errors';\n\nexport const customId = app => (nodeName, id) => {\n  const node = $(app.hierarchy, [\n    getFlattenedHierarchy,\n    find(n => n.name === nodeName),\n  ]);\n\n  if (!node) throw new NotFoundError(`Cannot find node ${nodeName}`);\n\n  return `${node.nodeId}-${id}`;\n};\n\nexport const setCustomId = app => (record, id) => {\n  record.id = customId(app)(record.type, id);\n\n  const keyParts = splitKey(record.key);\n\n  record.key = $(keyParts, [\n    take(keyParts.length - 1),\n    union([record.id]),\n    joinKey,\n  ]);\n\n  return record;\n};\n","import { getNew, getNewChild } from './getNew';\nimport { load } from './load';\nimport { validate } from './validate';\nimport { getContext } from './getContext';\nimport { save } from './save';\nimport { deleteRecord } from './delete';\nimport { uploadFile } from './uploadFile';\nimport { downloadFile } from './downloadFile';\nimport { customId, setCustomId } from './customId';\n\nconst api = app => ({\n  getNew: getNew(app),\n  getNewChild: getNewChild(app),\n  save: save(app),\n  load: load(app),\n  delete: deleteRecord(app, false),\n  validate: validate(app),\n  getContext: getContext(app),\n  uploadFile: uploadFile(app),\n  downloadFile: downloadFile(app),\n  customId: customId(app),\n  setCustomId: setCustomId(app),\n});\n\n\nexport const getRecordApi = app => api(app);\n\nexport default getRecordApi;\n","import { getNodeForCollectionPath } from '../templateApi/hierarchy';\nimport {\n  isNothing, safeKey, apiWrapperSync, events,\n} from '../common';\nimport { alwaysAuthorized } from '../authApi/permissions';\n\nexport const getAllowedRecordTypes = app => key => apiWrapperSync(\n  app,\n  events.collectionApi.getAllowedRecordTypes,\n  alwaysAuthorized,\n  { key },\n  _getAllowedRecordTypes, app, key,\n);\n\nconst _getAllowedRecordTypes = (app, key) => {\n  key = safeKey(key);\n  const node = getNodeForCollectionPath(app.hierarchy)(key);\n  return isNothing(node) ? [] : [node.name];\n};\n","import { getAllIdsIterator } from '../indexing/allIds';\nimport { getAllowedRecordTypes } from './getAllowedRecordTypes';\nimport { deleteCollection } from './delete';\n\nexport const getCollectionApi = app => ({\n  getAllowedRecordTypes: getAllowedRecordTypes(app),\n  getAllIdsIterator: getAllIdsIterator(app),\n  delete: deleteCollection(app),\n});\n\nexport default getCollectionApi;\n","import {\n  filter, \n  includes, some,\n} from 'lodash/fp';\nimport { getAllIdsIterator } from '../indexing/allIds';\nimport {\n  getFlattenedHierarchy, getRecordNodeById,\n  getNode, isIndex,\n  isRecord, getAllowedRecordNodesForIndex,\n  fieldReversesReferenceToIndex,\n} from '../templateApi/hierarchy';\nimport {\n  joinKey, apiWrapper, events, $\n} from '../common';\nimport {\n  createBuildIndexFolder,\n  transactionForBuildIndex,\n} from '../transactions/create';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\n\n\n/** rebuilds an index\n * @param {object} app - the application container\n * @param {string} indexNodeKey - node key of the index, which the index belongs to\n */\nexport const buildIndex = app => async indexNodeKey => apiWrapper(\n  app,\n  events.indexApi.buildIndex,\n  permission.manageIndex.isAuthorized,\n  { indexNodeKey },\n  _buildIndex, app, indexNodeKey,\n);\n\nconst _buildIndex = async (app, indexNodeKey) => {\n  const indexNode = getNode(app.hierarchy, indexNodeKey);\n\n  await createBuildIndexFolder(app.datastore, indexNodeKey);\n\n  if (!isIndex(indexNode)) { throw new BadRequestError('BuildIndex: must supply an indexnode'); }\n\n  if (indexNode.indexType === 'reference') {\n    await buildReverseReferenceIndex(\n      app, indexNode,\n    );\n  } else {\n    await buildHeirarchalIndex(\n      app, indexNode,\n    );\n  }\n\n  await app.cleanupTransactions();\n};\n\nconst buildReverseReferenceIndex = async (app, indexNode) => {\n  // Iterate through all referencING records,\n  // and update referenced index for each record\n  let recordCount = 0;\n  const referencingNodes = $(app.hierarchy, [\n    getFlattenedHierarchy,\n    filter(n => isRecord(n)\n                    && some(fieldReversesReferenceToIndex(indexNode))(n.fields)),\n  ]);\n\n  const createTransactionsForReferencingNode = async (referencingNode) => {\n    const iterateReferencingNodes = await getAllIdsIterator(app)(referencingNode.collectionNodeKey());\n\n    let referencingIdIterator = await iterateReferencingNodes();\n    while (!referencingIdIterator.done) {\n      const { result } = referencingIdIterator;\n      for (const id of result.ids) {\n        const recordKey = joinKey(result.collectionKey, id);\n        await transactionForBuildIndex(app, indexNode.nodeKey(), recordKey, recordCount);\n        recordCount++;\n      }\n      referencingIdIterator = await iterateReferencingNodes();\n    }\n  };\n\n  for (const referencingNode of referencingNodes) {\n    await createTransactionsForReferencingNode(referencingNode);\n  }\n};\n\n/*\nconst getAllowedParentCollectionNodes = (hierarchy, indexNode) => $(getAllowedRecordNodesForIndex(hierarchy, indexNode), [\n  map(n => n.parent()),\n]);\n*/\n\nconst buildHeirarchalIndex = async (app, indexNode) => {\n  let recordCount = 0;\n\n  const createTransactionsForIds = async (collectionKey, ids) => {\n    for (const recordId of ids) {\n      const recordKey = joinKey(collectionKey, recordId);\n\n      const recordNode = getRecordNodeById(\n        app.hierarchy,\n        recordId,\n      );\n\n      if (recordNodeApplies(indexNode)(recordNode)) {\n        await transactionForBuildIndex(\n          app, indexNode.nodeKey(),\n          recordKey, recordCount,\n        );\n        recordCount++;\n      }\n    }\n  };\n\n\n  const collectionRecords = getAllowedRecordNodesForIndex(app.hierarchy, indexNode);\n\n  for (const targetCollectionRecordNode of collectionRecords) {\n    const allIdsIterator = await getAllIdsIterator(app)(targetCollectionRecordNode.collectionNodeKey());\n\n    let allIds = await allIdsIterator();\n    while (allIds.done === false) {\n      await createTransactionsForIds(\n        allIds.result.collectionKey,\n        allIds.result.ids,\n      );\n      allIds = await allIdsIterator();\n    }\n  }\n\n  return recordCount;\n};\n\n// const chooseChildRecordNodeByKey = (collectionNode, recordId) => find(c => recordId.startsWith(c.nodeId))(collectionNode.children);\n\nconst recordNodeApplies = indexNode => recordNode => includes(recordNode.nodeId)(indexNode.allowedRecordNodeIds);\n\n/*\nconst hasApplicableDecendant = (hierarchy, ancestorNode, indexNode) => $(hierarchy, [\n  getFlattenedHierarchy,\n  filter(\n    allTrue(\n      isRecord,\n      isDecendant(ancestorNode),\n      recordNodeApplies(indexNode),\n    ),\n  ),\n]);\n*/\n\n /*\nconst applyAllDecendantRecords = async (app, collection_Key_or_NodeKey,\n  indexNode, indexKey, currentIndexedData,\n  currentIndexedDataKey, recordCount = 0) => {\n  const collectionNode = getCollectionNodeByKeyOrNodeKey(\n    app.hierarchy,\n    collection_Key_or_NodeKey,\n  );\n\n  const allIdsIterator = await getAllIdsIterator(app)(collection_Key_or_NodeKey);\n\n\n  const createTransactionsForIds = async (collectionKey, allIds) => {\n    for (const recordId of allIds) {\n      const recordKey = joinKey(collectionKey, recordId);\n\n      const recordNode = chooseChildRecordNodeByKey(\n        collectionNode,\n        recordId,\n      );\n\n      if (recordNodeApplies(indexNode)(recordNode)) {\n        await transactionForBuildIndex(\n          app, indexNode.nodeKey(),\n          recordKey, recordCount,\n        );\n        recordCount++;\n      }\n\n      if (hasApplicableDecendant(app.hierarchy, recordNode, indexNode)) {\n        for (const childCollectionNode of recordNode.children) {\n          recordCount = await applyAllDecendantRecords(\n            app,\n            joinKey(recordKey, childCollectionNode.collectionName),\n            indexNode, indexKey, currentIndexedData,\n            currentIndexedDataKey, recordCount,\n          );\n        }\n      }\n    }\n  };\n\n  let allIds = await allIdsIterator();\n  while (allIds.done === false) {\n    await createTransactionsForIds(\n      allIds.result.collectionKey,\n      allIds.result.ids,\n    );\n    allIds = await allIdsIterator();\n  }\n\n  return recordCount;\n};\n*/\n\nexport default buildIndex;\n","import { has, isNumber, isUndefined } from 'lodash/fp';\nimport { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  safeKey, apiWrapper,\n  events, isNonEmptyString,\n} from '../common';\nimport { iterateIndex } from '../indexing/read';\nimport {\n  getUnshardedIndexDataKey,\n  getShardKeysInRange,\n} from '../indexing/sharding';\nimport {\n  getExactNodeForKey, isIndex,\n  isShardedIndex,\n} from '../templateApi/hierarchy';\nimport { CONTINUE_READING_RECORDS } from '../indexing/serializer';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\nimport { getIndexDir } from \"./getIndexDir\";\n\nexport const aggregates = app => async (indexKey, rangeStartParams = null, rangeEndParams = null) => apiWrapper(\n  app,\n  events.indexApi.aggregates,\n  permission.readIndex.isAuthorized(indexKey),\n  { indexKey, rangeStartParams, rangeEndParams },\n  _aggregates, app, indexKey, rangeStartParams, rangeEndParams,\n);\n\nconst _aggregates = async (app, indexKey, rangeStartParams, rangeEndParams) => {\n  indexKey = safeKey(indexKey);\n  const indexNode = getExactNodeForKey(app.hierarchy)(indexKey);\n  const indexDir = getIndexDir(app.hierarchy, indexKey);\n\n  if (!isIndex(indexNode)) { throw new BadRequestError('supplied key is not an index'); }\n\n  if (isShardedIndex(indexNode)) {\n    const shardKeys = await getShardKeysInRange(\n      app, indexNode, indexDir, rangeStartParams, rangeEndParams,\n    );\n    let aggregateResult = null;\n    for (const k of shardKeys) {\n      const shardResult = await getAggregates(app.hierarchy, app.datastore, indexNode, k);\n      if (aggregateResult === null) {\n        aggregateResult = shardResult;\n      } else {\n        aggregateResult = mergeShardAggregate(\n          aggregateResult,\n          shardResult,\n        );\n      }\n    }\n    return aggregateResult;\n  }\n  return await getAggregates(\n    app.hierarchy,\n    app.datastore,\n    indexNode,\n    getUnshardedIndexDataKey(indexDir),\n  );\n};\n\nconst mergeShardAggregate = (totals, shard) => {\n  const mergeGrouping = (tot, shr) => {\n    tot.count += shr.count;\n    for (const aggName in tot) {\n      if (aggName === 'count') continue;\n      const totagg = tot[aggName];\n      const shragg = shr[aggName];\n      totagg.sum += shragg.sum;\n      totagg.max = totagg.max > shragg.max\n        ? totagg.max\n        : shragg.max;\n      totagg.min = totagg.min < shragg.min\n        ? totagg.min\n        : shragg.min;\n      totagg.mean = totagg.sum / tot.count;\n    }\n    return tot;\n  };\n\n  for (const aggGroupDef in totals) {\n    for (const grouping in shard[aggGroupDef]) {\n      const groupingTotal = totals[aggGroupDef][grouping];\n      totals[aggGroupDef][grouping] = isUndefined(groupingTotal)\n        ? shard[aggGroupDef][grouping]\n        : mergeGrouping(\n          totals[aggGroupDef][grouping],\n          shard[aggGroupDef][grouping],\n        );\n    }\n  }\n\n  return totals;\n};\n\nconst getAggregates = async (hierarchy, datastore, index, indexedDataKey) => {\n  const aggregateResult = {};\n  const doRead = iterateIndex(\n        async item => {\n      applyItemToAggregateResult(\n        index, aggregateResult, item,\n      );\n      return CONTINUE_READING_RECORDS;\n    },\n        async () => aggregateResult\n  );\n\n  return await doRead(hierarchy, datastore, index, indexedDataKey);\n};\n\n\nconst applyItemToAggregateResult = (indexNode, result, item) => {\n  const getInitialAggregateResult = () => ({\n    sum: 0, mean: null, max: null, min: null,\n  });\n\n  const applyAggregateResult = (agg, existing, count) => {\n    const value = compileCode(agg.aggregatedValue)({ record: item });\n\n    if (!isNumber(value)) return existing;\n\n    existing.sum += value;\n    existing.max = value > existing.max || existing.max === null\n      ? value\n      : existing.max;\n    existing.min = value < existing.min || existing.min === null\n      ? value\n      : existing.min;\n    existing.mean = existing.sum / count;\n    return existing;\n  };\n\n  for (const aggGroup of indexNode.aggregateGroups) {\n    if (!has(aggGroup.name)(result)) {\n      result[aggGroup.name] = {};\n    }\n\n    const thisGroupResult = result[aggGroup.name];\n\n    if (isNonEmptyString(aggGroup.condition)) {\n      if (!compileExpression(aggGroup.condition)({ record: item })) {\n        continue;\n      }\n    }\n\n    let group = isNonEmptyString(aggGroup.groupBy)\n      ? compileCode(aggGroup.groupBy)({ record: item })\n      : 'all';\n    if (!isNonEmptyString(group)) {\n      group = '(none)';\n    }\n\n    if (!has(group)(thisGroupResult)) {\n      thisGroupResult[group] = { count: 0 };\n      for (const agg of aggGroup.aggregates) {\n        thisGroupResult[group][agg.name] = getInitialAggregateResult();\n      }\n    }\n\n    thisGroupResult[group].count++;\n\n    for (const agg of aggGroup.aggregates) {\n      const existingValues = thisGroupResult[group][agg.name];\n      thisGroupResult[group][agg.name] = applyAggregateResult(\n        agg, existingValues,\n        thisGroupResult[group].count,\n      );\n    }\n  }\n};\n","import { buildIndex } from './buildIndex';\nimport { listItems } from './listItems';\nimport { aggregates } from './aggregates';\n\nexport const getIndexApi = app => ({\n  listItems: listItems(app),\n  buildIndex: buildIndex(app),\n  aggregates: aggregates(app),\n});\n\nexport default getIndexApi;\n","import { each, find } from 'lodash';\nimport { map, max, constant } from 'lodash/fp';\nimport {\n  switchCase, defaultCase, joinKey,\n  $, isNothing, isSomething,\n} from '../common';\nimport {\n  isIndex, isRoot, isSingleRecord, isCollectionRecord,\n  isRecord, isaggregateGroup,\n  getFlattenedHierarchy,\n} from './hierarchy';\nimport { all } from '../types';\nimport { BadRequestError } from '../common/errors';\n\nexport const createNodeErrors = {\n  indexCannotBeParent: 'Index template cannot be a parent',\n  allNonRootNodesMustHaveParent: 'Only the root node may have no parent',\n  indexParentMustBeRecordOrRoot: 'An index may only have a record or root as a parent',\n  aggregateParentMustBeAnIndex: 'aggregateGroup parent must be an index',\n};\n\nconst pathRegxMaker = node => () => node.nodeKey().replace(/{id}/g, '[a-zA-Z0-9_-]+');\n\nconst nodeKeyMaker = node => () => switchCase(\n\n  [n => isRecord(n) && !isSingleRecord(n),\n    n => joinKey(\n      node.parent().nodeKey(),\n      node.collectionName,\n      `${n.nodeId}-{id}`,\n    )],\n\n  [isRoot,\n    constant('/')],\n\n  [defaultCase,\n    n => joinKey(node.parent().nodeKey(), n.name)],\n\n)(node);\n\n\nconst validate = parent => (node) => {\n  if (isIndex(node)\n        && isSomething(parent)\n        && !isRoot(parent)\n        && !isRecord(parent)) {\n    throw new BadRequestError(createNodeErrors.indexParentMustBeRecordOrRoot);\n  }\n\n  if (isaggregateGroup(node)\n        && isSomething(parent)\n        && !isIndex(parent)) {\n    throw new BadRequestError(createNodeErrors.aggregateParentMustBeAnIndex);\n  }\n\n  if (isNothing(parent) && !isRoot(node)) { throw new BadRequestError(createNodeErrors.allNonRootNodesMustHaveParent); }\n\n  return node;\n};\n\nconst construct = parent => (node) => {\n  node.nodeKey = nodeKeyMaker(node);\n  node.pathRegx = pathRegxMaker(node);\n  node.parent = constant(parent);\n  node.isRoot = () => isNothing(parent)\n                        && node.name === 'root'\n                        && node.type === 'root';\n  if (isCollectionRecord(node)) {\n    node.collectionNodeKey = () => joinKey(\n      parent.nodeKey(), node.collectionName,\n    );\n    node.collectionPathRegx = () => joinKey(\n      parent.pathRegx(), node.collectionName,\n    );\n  }\n  return node;\n};\n\nconst addToParent = (obj) => {\n  const parent = obj.parent();\n  if (isSomething(parent)) {\n    if (isIndex(obj))\n    // Q: why are indexes not children ?\n    // A: because they cannot have children of their own.\n    { \n      parent.indexes.push(obj); \n    } \n    else if (isaggregateGroup(obj)) \n    { \n      parent.aggregateGroups.push(obj); \n    } else { \n      parent.children.push(obj); \n    }\n\n    if (isRecord(obj)) {\n      const defaultIndex = find(\n        parent.indexes,\n        i => i.name === `${parent.name}_index`,\n      );\n      if (defaultIndex) {\n        defaultIndex.allowedRecordNodeIds.push(obj.nodeId);\n      }\n    }\n  }\n  return obj;\n};\n\nexport const constructNode = (parent, obj) => $(obj, [\n  construct(parent),\n  validate(parent),\n  addToParent,\n]);\n\nconst getNodeId = (parentNode) => {\n  // this case is handled better elsewhere\n  if (!parentNode) return null;\n  const findRoot = n => (isRoot(n) ? n : findRoot(n.parent()));\n  const root = findRoot(parentNode);\n\n  return ($(root, [\n    getFlattenedHierarchy,\n    map(n => n.nodeId),\n    max]) + 1);\n};\n\nexport const constructHierarchy = (node, parent) => {\n  construct(parent)(node);\n  if (node.indexes) {\n    each(node.indexes,\n      child => constructHierarchy(child, node));\n  }\n  if (node.aggregateGroups) {\n    each(node.aggregateGroups,\n      child => constructHierarchy(child, node));\n  }\n  if (node.children && node.children.length > 0) {\n    each(node.children,\n      child => constructHierarchy(child, node));\n  }\n  if (node.fields) {\n    each(node.fields,\n      f => each(f.typeOptions, (val, key) => {\n        const def = all[f.type].optionDefinitions[key];\n        if (!def) {\n          // unknown typeOption\n          delete f.typeOptions[key];\n        } else {\n          f.typeOptions[key] = def.parse(val);\n        }\n      }));\n  }\n  return node;\n};\n\n\nexport const getNewRootLevel = () => construct()({\n  name: 'root',\n  type: 'root',\n  children: [],\n  pathMaps: [],\n  indexes: [],\n  nodeId: 0,\n});\n\nconst _getNewRecordTemplate = (parent, name, createDefaultIndex, isSingle) => {\n  const node = constructNode(parent, {\n    name,\n    type: 'record',\n    fields: [],\n    children: [],\n    validationRules: [],\n    nodeId: getNodeId(parent),\n    indexes: [],\n    estimatedRecordCount: isRecord(parent) ? 500 : 1000000,\n    collectionName: '',\n    isSingle,\n  });\n\n  if (createDefaultIndex) {\n    const defaultIndex = getNewIndexTemplate(parent);\n    defaultIndex.name = `${name}_index`;\n    defaultIndex.allowedRecordNodeIds.push(node.nodeId);\n  }\n\n  return node;\n};\n\nexport const getNewRecordTemplate = (parent, name = '', createDefaultIndex = true) => _getNewRecordTemplate(parent, name, createDefaultIndex, false);\n\nexport const getNewSingleRecordTemplate = parent => _getNewRecordTemplate(parent, '', false, true);\n\nexport const getNewIndexTemplate = (parent, type = 'ancestor') => constructNode(parent, {\n  name: '',\n  type: 'index',\n  map: 'return {...record};',\n  filter: '',\n  indexType: type,\n  getShardName: '',\n  getSortKey: 'record.id',\n  aggregateGroups: [],\n  allowedRecordNodeIds: [],\n  nodeId: getNodeId(parent),\n});\n\nexport const getNewAggregateGroupTemplate = index => constructNode(index, {\n  name: '',\n  type: 'aggregateGroup',\n  groupBy: '',\n  aggregates: [],\n  condition: '',\n  nodeId: getNodeId(index),\n});\n\nexport const getNewAggregateTemplate = (set) => {\n  const aggregatedValue = {\n    name: '',\n    aggregatedValue: '',\n  };\n  set.aggregates.push(aggregatedValue);\n  return aggregatedValue;\n};\n\nexport default {\n  getNewRootLevel,\n  getNewRecordTemplate,\n  getNewIndexTemplate,\n  createNodeErrors,\n  constructHierarchy,\n  getNewAggregateGroupTemplate,\n  getNewAggregateTemplate,\n};\n","import {\n  some, map, filter, keys, includes,\n  countBy, flatten,\n} from 'lodash/fp';\nimport {\n  isSomething, $,\n  isNonEmptyString,\n  isNothingOrEmpty,\n  isNothing,\n} from '../common';\nimport { all, getDefaultOptions } from '../types';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { BadRequestError } from '../common/errors';\n\nexport const fieldErrors = {\n  AddFieldValidationFailed: 'Add field validation: ',\n};\n\nexport const allowedTypes = () => keys(all);\n\nexport const getNewField = type => ({\n  name: '', // how field is referenced internally\n  type,\n  typeOptions: getDefaultOptions(type),\n  label: '', // how field is displayed\n  getInitialValue: 'default', // function that gets value when initially created\n  getUndefinedValue: 'default', // function that gets value when field undefined on record\n});\n\nconst fieldRules = allFields => [\n  makerule('name', 'field name is not set',\n    f => isNonEmptyString(f.name)),\n  makerule('type', 'field type is not set',\n    f => isNonEmptyString(f.type)),\n  makerule('label', 'field label is not set',\n    f => isNonEmptyString(f.label)),\n  makerule('getInitialValue', 'getInitialValue function is not set',\n    f => isNonEmptyString(f.getInitialValue)),\n  makerule('getUndefinedValue', 'getUndefinedValue function is not set',\n    f => isNonEmptyString(f.getUndefinedValue)),\n  makerule('name', 'field name is duplicated',\n    f => isNothingOrEmpty(f.name)\n             || countBy('name')(allFields)[f.name] === 1),\n  makerule('type', 'type is unknown',\n    f => isNothingOrEmpty(f.type)\n             || some(t => f.type === t)(allowedTypes())),\n];\n\nconst typeOptionsRules = (field) => {\n  const type = all[field.type];\n  if (isNothing(type)) return [];\n\n  const def = optName => type.optionDefinitions[optName];\n\n  return $(field.typeOptions, [\n    keys,\n    filter(o => isSomething(def(o))\n                    && isSomething(def(o).isValid)),\n    map(o => makerule(\n      `typeOptions.${o}`,\n      `${def(o).requirementDescription}`,\n      field => def(o).isValid(field.typeOptions[o]),\n    )),\n  ]);\n};\n\nexport const validateField = allFields => (field) => {\n  const everySingleField = includes(field)(allFields) ? allFields : [...allFields, field];\n  return applyRuleSet([...fieldRules(everySingleField), ...typeOptionsRules(field)])(field);\n};\n\nexport const validateAllFields = recordNode => $(recordNode.fields, [\n  map(validateField(recordNode.fields)),\n  flatten,\n]);\n\nexport const addField = (recordTemplate, field) => {\n  if (isNothingOrEmpty(field.label)) {\n    field.label = field.name;\n  }\n  const validationMessages = validateField([...recordTemplate.fields, field])(field);\n  if (validationMessages.length > 0) {\n    const errors = map(m => m.error)(validationMessages);\n    throw new BadRequestError(`${fieldErrors.AddFieldValidationFailed} ${errors.join(', ')}`);\n  }\n  recordTemplate.fields.push(field);\n};\n","import { isNumber, isBoolean, defaultCase } from 'lodash/fp';\nimport { switchCase } from '../common';\n\nexport const getNewRecordValidationRule = (invalidFields,\n  messageWhenInvalid,\n  expressionWhenValid) => ({\n  invalidFields, messageWhenInvalid, expressionWhenValid,\n});\n\nconst getStaticValue = switchCase(\n  [isNumber, v => v.toString()],\n  [isBoolean, v => v.toString()],\n  [defaultCase, v => `'${v}'`],\n);\n\nexport const commonRecordValidationRules = ({\n\n  fieldNotEmpty: fieldName => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} is empty`,\n    `!_.isEmpty(record['${fieldName}'])`,\n  ),\n\n  fieldBetween: (fieldName, min, max) => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} must be between ${min.toString()} and ${max.toString()}`,\n    `record['${fieldName}'] >= ${getStaticValue(min)} &&  record['${fieldName}'] <= ${getStaticValue(max)} `,\n  ),\n\n  fieldGreaterThan: (fieldName, min, max) => getNewRecordValidationRule(\n    [fieldName],\n    `${fieldName} must be greater than ${min.toString()} and ${max.toString()}`,\n    `record['${fieldName}'] >= ${getStaticValue(min)}  `,\n  ),\n});\n\nexport const addRecordValidationRule = recordNode => rule => recordNode.validationRules.push(rule);\n","\nexport const createTrigger = () => ({\n  actionName: '',\n  eventName: '',\n  // function, has access to event context,\n  // returns object that is used as parameter to action\n  // only used if triggered by event\n  optionsCreator: '',\n  // action runs if true,\n  // has access to event context\n  condition: '',\n});\n\nexport const createAction = () => ({\n  name: '',\n  behaviourSource: '',\n  // name of function in actionSource\n  behaviourName: '',\n  // parameter passed into behaviour.\n  // any other parms passed at runtime e.g.\n  // by trigger, or manually, will be merged into this\n  initialOptions: {},\n});\n","import { flatten, map, isEmpty } from 'lodash/fp';\nimport { compileCode } from '@nx-js/compiler-util';\nimport {\n  isNonEmptyString, \n  executesWithoutException, $, \n} from '../common';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\n\nconst aggregateRules = [\n  makerule('name', 'choose a name for the aggregate',\n    a => isNonEmptyString(a.name)),\n  makerule('aggregatedValue', 'aggregatedValue does not compile',\n    a => isEmpty(a.aggregatedValue)\n            || executesWithoutException(\n              () => compileCode(a.aggregatedValue),\n            )),\n];\n\nexport const validateAggregate = aggregate => applyRuleSet(aggregateRules)(aggregate);\n\nexport const validateAllAggregates = all => $(all, [\n  map(validateAggregate),\n  flatten,\n]);\n","import {\n  filter, union, constant,\n  map, flatten, every, uniqBy,\n  some, includes, isEmpty, has\n} from 'lodash/fp';\nimport { compileExpression, compileCode } from '@nx-js/compiler-util';\nimport {\n  $, isSomething, switchCase,\n  anyTrue, isNonEmptyArray, executesWithoutException,\n  isNonEmptyString, defaultCase,\n} from '../common';\nimport {\n  isRecord, isRoot, isaggregateGroup,\n  isIndex, getFlattenedHierarchy,\n} from './hierarchy';\nimport { eventsList } from '../common/events';\nimport { validateAllFields } from './fields';\nimport {\n  applyRuleSet, makerule, stringNotEmpty,\n  validationError,\n} from '../common/validationCommon';\nimport { indexRuleSet } from './indexes';\nimport { validateAllAggregates } from './validateAggregate';\n\nexport const ruleSet = (...sets) => constant(flatten([...sets]));\n\nconst commonRules = [\n  makerule('name', 'node name is not set',\n    node => stringNotEmpty(node.name)),\n  makerule('type', 'node type not recognised',\n    anyTrue(isRecord, isRoot, isIndex, isaggregateGroup)),\n];\n\nconst recordRules = [\n  makerule('fields', 'no fields have been added to the record',\n    node => isNonEmptyArray(node.fields)),\n  makerule('validationRules', \"validation rule is missing a 'messageWhenValid' member\",\n    node => every(r => has('messageWhenInvalid')(r))(node.validationRules)),\n  makerule('validationRules', \"validation rule is missing a 'expressionWhenValid' member\",\n    node => every(r => has('expressionWhenValid')(r))(node.validationRules)),\n];\n\n\nconst aggregateGroupRules = [\n  makerule('condition', 'condition does not compile',\n    a => isEmpty(a.condition)\n             || executesWithoutException(\n               () => compileExpression(a.condition),\n             )),\n];\n\nconst getRuleSet = node => switchCase(\n\n  [isRecord, ruleSet(\n    commonRules,\n    recordRules,\n  )],\n\n  [isIndex, ruleSet(\n    commonRules,\n    indexRuleSet,\n  )],\n\n  [isaggregateGroup, ruleSet(\n    commonRules,\n    aggregateGroupRules,\n  )],\n\n  [defaultCase, ruleSet(commonRules, [])],\n)(node);\n\nexport const validateNode = node => applyRuleSet(getRuleSet(node))(node);\n\nexport const validateAll = (appHierarchy) => {\n  const flattened = getFlattenedHierarchy(\n    appHierarchy,\n  );\n\n  const duplicateNameRule = makerule(\n    'name', 'node names must be unique under shared parent',\n    n => filter(f => f.parent() === n.parent()\n                          && f.name === n.name)(flattened).length === 1,\n  );\n\n  const duplicateNodeKeyErrors = $(flattened, [\n    map(n => applyRuleSet([duplicateNameRule])(n)),\n    filter(isSomething),\n    flatten,\n  ]);\n\n  const fieldErrors = $(flattened, [\n    filter(isRecord),\n    map(validateAllFields),\n    flatten,\n  ]);\n\n  const aggregateErrors = $(flattened, [\n    filter(isaggregateGroup),\n    map(s => validateAllAggregates(\n      s.aggregates,\n    )),\n    flatten,\n  ]);\n\n  return $(flattened, [\n    map(validateNode),\n    flatten,\n    union(duplicateNodeKeyErrors),\n    union(fieldErrors),\n    union(aggregateErrors),\n  ]);\n};\n\nconst actionRules = [\n  makerule('name', 'action must have a name',\n    a => isNonEmptyString(a.name)),\n  makerule('behaviourName', 'must supply a behaviour name to the action',\n    a => isNonEmptyString(a.behaviourName)),\n  makerule('behaviourSource', 'must supply a behaviour source for the action',\n    a => isNonEmptyString(a.behaviourSource)),\n];\n\nconst duplicateActionRule = makerule('', 'action name must be unique', () => {});\n\nconst validateAction = action => applyRuleSet(actionRules)(action);\n\n\nexport const validateActions = (allActions) => {\n  const duplicateActions = $(allActions, [\n    filter(a => filter(a2 => a2.name === a.name)(allActions).length > 1),\n    map(a => validationError(duplicateActionRule, a)),\n  ]);\n\n  const errors = $(allActions, [\n    map(validateAction),\n    flatten,\n    union(duplicateActions),\n    uniqBy('name'),\n  ]);\n\n  return errors;\n};\n\nconst triggerRules = actions => ([\n  makerule('actionName', 'must specify an action',\n    t => isNonEmptyString(t.actionName)),\n  makerule('eventName', 'must specify and event',\n    t => isNonEmptyString(t.eventName)),\n  makerule('actionName', 'specified action not supplied',\n    t => !t.actionName\n             || some(a => a.name === t.actionName)(actions)),\n  makerule('eventName', 'invalid Event Name',\n    t => !t.eventName\n             || includes(t.eventName)(eventsList)),\n  makerule('optionsCreator', 'Options Creator does not compile - check your expression',\n    (t) => {\n      if (!t.optionsCreator) return true;\n      try {\n        compileCode(t.optionsCreator);\n        return true;\n      } catch (_) { return false; }\n    }),\n  makerule('condition', 'Trigger condition does not compile - check your expression',\n    (t) => {\n      if (!t.condition) return true;\n      try {\n        compileExpression(t.condition);\n        return true;\n      } catch (_) { return false; }\n    }),\n]);\n\nexport const validateTrigger = (trigger, allActions) => {\n  const errors = applyRuleSet(triggerRules(allActions))(trigger);\n\n  return errors;\n};\n\nexport const validateTriggers = (triggers, allActions) => $(triggers, [\n  map(t => validateTrigger(t, allActions)),\n  flatten,\n]);\n","import { appDefinitionFile } from '../common';\nimport { constructHierarchy } from './createNodes';\n\nexport const getApplicationDefinition = datastore => async () => {\n  const exists = await datastore.exists(appDefinitionFile);\n\n  if (!exists) throw new Error('Application definition does not exist');\n\n  const appDefinition = await datastore.loadJson(appDefinitionFile);\n  appDefinition.hierarchy = constructHierarchy(\n    appDefinition.hierarchy,\n  );\n  return appDefinition;\n};\n","import { join } from 'lodash';\nimport { permission } from '../authApi/permissions';\nimport { appDefinitionFile } from '../common';\nimport { validateAll } from './validate';\nimport { apiWrapper } from '../common/apiWrapper';\nimport { events } from '../common/events';\n\nexport const saveApplicationHierarchy = app => async hierarchy => apiWrapper(\n  app,\n  events.templateApi.saveApplicationHierarchy,\n  permission.writeTemplates.isAuthorized,\n  { hierarchy },\n  _saveApplicationHierarchy, app.datastore, hierarchy,\n);\n\n\nexport const _saveApplicationHierarchy = async (datastore, hierarchy) => {\n  const validationErrors = await validateAll(hierarchy);\n  if (validationErrors.length > 0) {\n    throw new Error(`Hierarchy is invalid: ${join(\n      validationErrors.map(e => `${e.item.nodeKey ? e.item.nodeKey() : ''} : ${e.error}`),\n      ',',\n    )}`);\n  }\n\n  if (await datastore.exists(appDefinitionFile)) {\n    const appDefinition = await datastore.loadJson(appDefinitionFile);\n    appDefinition.hierarchy = hierarchy;\n    await datastore.updateJson(appDefinitionFile, appDefinition);\n  } else {\n    await datastore.createFolder('/.config');\n    const appDefinition = { actions: [], triggers: [], hierarchy };\n    await datastore.createJson(appDefinitionFile, appDefinition);\n  }\n};\n","import { join } from 'lodash';\nimport { map } from 'lodash/fp';\nimport { appDefinitionFile } from '../common';\nimport { validateTriggers, validateActions } from './validate';\nimport { apiWrapper } from '../common/apiWrapper';\nimport { events } from '../common/events';\nimport { permission } from '../authApi/permissions';\nimport { BadRequestError } from '../common/errors';\n\nexport const saveActionsAndTriggers = app => async (actions, triggers) => apiWrapper(\n  app,\n  events.templateApi.saveActionsAndTriggers,\n  permission.writeTemplates.isAuthorized,\n  { actions, triggers },\n  _saveActionsAndTriggers, app.datastore, actions, triggers,\n);\n\nexport const _saveActionsAndTriggers = async (datastore, actions, triggers) => {\n  if (await datastore.exists(appDefinitionFile)) {\n    const appDefinition = await datastore.loadJson(appDefinitionFile);\n    appDefinition.actions = actions;\n    appDefinition.triggers = triggers;\n\n    const actionValidErrs = map(e => e.error)(validateActions(actions));\n\n    if (actionValidErrs.length > 0) {\n      throw new BadRequestError(`Actions are invalid: ${join(actionValidErrs, ', ')}`);\n    }\n\n    const triggerValidErrs = map(e => e.error)(validateTriggers(triggers, actions));\n\n    if (triggerValidErrs.length > 0) {\n      throw new BadRequestError(`Triggers are invalid: ${join(triggerValidErrs, ', ')}`);\n    }\n\n    await datastore.updateJson(appDefinitionFile, appDefinition);\n  } else {\n    throw new BadRequestError('Cannot save actions: Application definition does not exist');\n  }\n};\n","\nexport const getBehaviourSources = async (datastore) => {\n    await datastore.loadFile('/.config/behaviourSources.js');\n};\n","import {\n  getNewRootLevel,\n  getNewRecordTemplate, getNewIndexTemplate,\n  createNodeErrors, constructHierarchy,\n  getNewAggregateGroupTemplate, getNewSingleRecordTemplate,\n  getNewAggregateTemplate, constructNode,\n}\n  from './createNodes';\nimport {\n  getNewField, validateField,\n  addField, fieldErrors,\n} from './fields';\nimport {\n  getNewRecordValidationRule, commonRecordValidationRules,\n  addRecordValidationRule,\n} from './recordValidationRules';\nimport { createAction, createTrigger } from './createActions';\nimport {\n  validateTriggers, validateTrigger, validateNode,\n  validateActions, validateAll,\n} from './validate';\nimport { getApplicationDefinition } from './getApplicationDefinition';\nimport { saveApplicationHierarchy } from './saveApplicationHierarchy';\nimport { saveActionsAndTriggers } from './saveActionsAndTriggers';\nimport { all } from '../types';\nimport { getBehaviourSources } from \"./getBehaviourSources\";\n\nconst api = app => ({\n\n  getApplicationDefinition: getApplicationDefinition(app.datastore),\n  saveApplicationHierarchy: saveApplicationHierarchy(app),\n  saveActionsAndTriggers: saveActionsAndTriggers(app),\n  getBehaviourSources: () => getBehaviourSources(app.datastore),\n  getNewRootLevel,\n  constructNode,\n  getNewIndexTemplate,\n  getNewRecordTemplate,\n  getNewField,\n  validateField,\n  addField,\n  fieldErrors,\n  getNewRecordValidationRule,\n  commonRecordValidationRules,\n  addRecordValidationRule,\n  createAction,\n  createTrigger,\n  validateActions,\n  validateTrigger,\n  getNewAggregateGroupTemplate,\n  getNewAggregateTemplate,\n  constructHierarchy,\n  getNewSingleRecordTemplate,\n  allTypes: all,\n  validateNode,\n  validateAll,\n  validateTriggers,\n});\n\n\nexport const getTemplateApi = app => api(app);\n\nexport const errors = createNodeErrors;\n\nexport default getTemplateApi;\n","import { map } from 'lodash/fp';\nimport {\n  USERS_LIST_FILE,\n  stripUserOfSensitiveStuff,\n} from './authCommon';\nimport { $, apiWrapper, events } from '../common';\nimport { permission } from './permissions';\n\nexport const getUsers = app => async () => apiWrapper(\n  app,\n  events.authApi.getUsers,\n  permission.listUsers.isAuthorized,\n  {},\n  _getUsers, app,\n);\n\nexport const _getUsers = async app => $(await app.datastore.loadJson(USERS_LIST_FILE), [\n  map(stripUserOfSensitiveStuff),\n]);\n","import { ACCESS_LEVELS_FILE } from './authCommon';\nimport { apiWrapper, events } from '../common';\nimport { permission } from './permissions';\n\nexport const loadAccessLevels = app => async () => apiWrapper(\n  app,\n  events.authApi.loadAccessLevels,\n  permission.listAccessLevels.isAuthorized,\n  {},\n  _loadAccessLevels, app,\n);\n\nexport const _loadAccessLevels = async app => await app.datastore.loadJson(ACCESS_LEVELS_FILE);\n","import {\n  find, filter, some,\n  map, flatten,\n} from 'lodash/fp';\nimport { generate } from 'shortid';\nimport { _getUsers } from './getUsers';\nimport {\n  getUserByName, userAuthFile,\n  parseTemporaryCode,\n} from './authCommon';\nimport { _loadAccessLevels } from './loadAccessLevels';\nimport {\n  isNothingOrEmpty, $, apiWrapper, events,\n} from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nconst dummyHash = '$argon2i$v=19$m=4096,t=3,p=1$UZRo409UYBGjHJS3CV6Uxw$rU84qUqPeORFzKYmYY0ceBLDaPO+JWSH4PfNiKXfIKk';\n\nexport const authenticate = app => async (username, password) => apiWrapper(\n  app,\n  events.authApi.authenticate,\n  alwaysAuthorized,\n  { username, password },\n  _authenticate, app, username, password,\n);\n\nexport const _authenticate = async (app, username, password) => {\n  if (isNothingOrEmpty(username) || isNothingOrEmpty(password)) { return null; }\n\n  const allUsers = await _getUsers(app);\n  let user = getUserByName(\n    allUsers,\n    username,\n  );\n\n  const notAUser = 'not-a-user';\n  // continue with non-user - so time to verify remains consistent\n  // with verification of a valid user\n  if (!user || !user.enabled) { user = notAUser; }\n\n  let userAuth;\n  try {\n    userAuth = await app.datastore.loadJson(\n      userAuthFile(username),\n    );\n  } catch (_) {\n    userAuth = { accessLevels: [], passwordHash: dummyHash };\n  }\n\n  const permissions = await buildUserPermissions(app, user.accessLevels);\n\n  const verified = await app.crypto.verify(\n    userAuth.passwordHash,\n    password,\n  );\n\n  if (user === notAUser) { return null; }\n\n  return verified\n    ? {\n      ...user, permissions, temp: false, isUser: true,\n    }\n    : null;\n};\n\nexport const authenticateTemporaryAccess = app => async (tempAccessCode) => {\n  if (isNothingOrEmpty(tempAccessCode)) { return null; }\n\n  const temp = parseTemporaryCode(tempAccessCode);\n  let user = $(await _getUsers(app), [\n    find(u => u.temporaryAccessId === temp.id),\n  ]);\n\n  const notAUser = 'not-a-user';\n  if (!user || !user.enabled) { user = notAUser; }\n\n  let userAuth;\n  try {\n    userAuth = await app.datastore.loadJson(\n      userAuthFile(user.name),\n    );\n  } catch (e) {\n    userAuth = {\n      temporaryAccessHash: dummyHash,\n      temporaryAccessExpiryEpoch: (await app.getEpochTime() + 10000),\n    };\n  }\n\n  if (userAuth.temporaryAccessExpiryEpoch < await app.getEpochTime()) { user = notAUser; }\n\n  const tempCode = !temp.code ? generate() : temp.code;\n  const verified = await app.crypto.verify(\n    userAuth.temporaryAccessHash,\n    tempCode,\n  );\n\n  if (user === notAUser) { return null; }\n\n  return verified\n    ? {\n      ...user,\n      permissions: [],\n      temp: true,\n      isUser: true,\n    }\n    : null;\n};\n\nexport const buildUserPermissions = async (app, userAccessLevels) => {\n  const allAccessLevels = await _loadAccessLevels(app);\n\n  return $(allAccessLevels.levels, [\n    filter(l => some(ua => l.name === ua)(userAccessLevels)),\n    map(l => l.permissions),\n    flatten,\n  ]);\n};\n","import { generate } from 'shortid';\nimport {\n  tempCodeExpiryLength, USERS_LOCK_FILE,\n  USERS_LIST_FILE, userAuthFile,\n  getUserByName,\n} from './authCommon';\nimport {\n  getLock, isNolock,\n  releaseLock,\n} from '../common/lock';\nimport { apiWrapper, events } from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nexport const createTemporaryAccess = app => async userName => apiWrapper(\n  app,\n  events.authApi.createTemporaryAccess,\n  alwaysAuthorized,\n  { userName },\n  _createTemporaryAccess, app, userName,\n);\n\nexport const _createTemporaryAccess = async (app, userName) => {\n  const tempCode = await getTemporaryCode(app);\n\n  const lock = await getLock(\n    app, USERS_LOCK_FILE, 1000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Unable to create temporary access, could not get lock - try again'); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n\n    const user = getUserByName(users, userName);\n    user.temporaryAccessId = tempCode.temporaryAccessId;\n\n    await app.datastore.updateJson(\n      USERS_LIST_FILE,\n      users,\n    );\n  } finally {\n    await releaseLock(app, lock);\n  }\n\n  const userAuth = await app.datastore.loadJson(\n    userAuthFile(userName),\n  );\n  userAuth.temporaryAccessHash = tempCode.temporaryAccessHash;\n\n  userAuth.temporaryAccessExpiryEpoch = tempCode.temporaryAccessExpiryEpoch;\n\n  await app.datastore.updateJson(\n    userAuthFile(userName),\n    userAuth,\n  );\n\n  return tempCode.tempCode;\n};\n\nexport const getTemporaryCode = async (app) => {\n  const tempCode = generate()\n        + generate()\n        + generate()\n        + generate();\n\n  const tempId = generate();\n\n  return {\n    temporaryAccessHash: await app.crypto.hash(\n      tempCode,\n    ),\n    temporaryAccessExpiryEpoch:\n            (await app.getEpochTime()) + tempCodeExpiryLength,\n    tempCode: `tmp:${tempId}:${tempCode}`,\n    temporaryAccessId: tempId,\n  };\n};\n\nexport const looksLikeTemporaryCode = code => code.startsWith('tmp:');\n","import {\n  map, uniqWith,\n  flatten, filter,\n} from 'lodash/fp';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport {\n  $, insensitiveEquals, apiWrapper, events,\n  isNonEmptyString, all,\n} from '../common';\nimport { alwaysAuthorized } from './permissions';\n\nconst userRules = allUsers => [\n  makerule('name', 'username must be set',\n    u => isNonEmptyString(u.name)),\n  makerule('accessLevels', 'user must have at least one access level',\n    u => u.accessLevels.length > 0),\n  makerule('name', 'username must be unique',\n    u => filter(u2 => insensitiveEquals(u2.name, u.name))(allUsers).length === 1),\n  makerule('accessLevels', 'access levels must only contain stings',\n    u => all(isNonEmptyString)(u.accessLevels)),\n];\n\nexport const validateUser = () => (allusers, user) => applyRuleSet(userRules(allusers))(user);\n\nexport const validateUsers = app => allUsers => apiWrapper(\n  app,\n  events.authApi.validateUsers,\n  alwaysAuthorized,\n  { allUsers },\n  _validateUsers, app, allUsers,\n);\n\nexport const _validateUsers = (app, allUsers) => $(allUsers, [\n  map(l => validateUser(app)(allUsers, l)),\n  flatten,\n  uniqWith((x, y) => x.field === y.field\n                        && x.item === y.item\n                        && x.error === y.error),\n]);\n","import { apiWrapperSync, events } from '../common';\nimport { permission } from './permissions';\n\nexport const getNewUser = app => () => apiWrapperSync(\n  app,\n  events.authApi.getNewUser,\n  permission.createUser.isAuthorized,\n  {},\n  _getNewUser, app,\n);\n\nexport const _getNewUser = () => ({\n  name: '',\n  accessLevels: [],\n  enabled: true,\n  temporaryAccessId: '',\n});\n\nexport const getNewUserAuth = app => () => apiWrapperSync(\n  app,\n  events.authApi.getNewUserAuth,\n  permission.createUser.isAuthorized,\n  {},\n  _getNewUserAuth, app,\n);\n\nexport const _getNewUserAuth = () => ({\n  passwordHash: '',\n  temporaryAccessHash: '',\n  temporaryAccessExpiryEpoch: 0,\n});\n","import { find } from 'lodash/fp';\nimport { userAuthFile, parseTemporaryCode } from './authCommon';\nimport {\n  isSomething, $, apiWrapper, apiWrapperSync, events,\n} from '../common';\nimport { _getUsers } from './getUsers';\nimport { alwaysAuthorized } from './permissions';\n\nexport const isValidPassword = app => password => apiWrapperSync(\n  app,\n  events.authApi.isValidPassword,\n  alwaysAuthorized,\n  { password },\n  _isValidPassword, app, password,\n);\n\nexport const _isValidPassword = (app, password) => scorePassword(password).score > 30;\n\nexport const changeMyPassword = app => async (currentPw, newpassword) => apiWrapper(\n  app,\n  events.authApi.changeMyPassword,\n  alwaysAuthorized,\n  { currentPw, newpassword },\n  _changeMyPassword, app, currentPw, newpassword,\n);\n\nexport const _changeMyPassword = async (app, currentPw, newpassword) => {\n  const existingAuth = await app.datastore.loadJson(\n    userAuthFile(app.user.name),\n  );\n\n  if (isSomething(existingAuth.passwordHash)) {\n    const verified = await app.crypto.verify(\n      existingAuth.passwordHash,\n      currentPw,\n    );\n\n    if (verified) {\n      await await doSet(\n        app, existingAuth,\n        app.user.name, newpassword,\n      );\n      return true;\n    }\n  }\n\n  return false;\n};\n\nexport const setPasswordFromTemporaryCode = app => async (tempCode, newpassword) => apiWrapper(\n  app,\n  events.authApi.setPasswordFromTemporaryCode,\n  alwaysAuthorized,\n  { tempCode, newpassword },\n  _setPasswordFromTemporaryCode, app, tempCode, newpassword,\n);\n\n\nexport const _setPasswordFromTemporaryCode = async (app, tempCode, newpassword) => {\n  const currentTime = await app.getEpochTime();\n\n  const temp = parseTemporaryCode(tempCode);\n\n  const user = $(await _getUsers(app), [\n    find(u => u.temporaryAccessId === temp.id),\n  ]);\n\n  if (!user) { return false; }\n\n  const existingAuth = await app.datastore.loadJson(\n    userAuthFile(user.name),\n  );\n\n  if (isSomething(existingAuth.temporaryAccessHash)\n       && existingAuth.temporaryAccessExpiryEpoch > currentTime) {\n    const verified = await app.crypto.verify(\n      existingAuth.temporaryAccessHash,\n      temp.code,\n    );\n\n    if (verified) {\n      await doSet(\n        app, existingAuth,\n        user.name, newpassword,\n      );\n      return true;\n    }\n  }\n\n  return false;\n};\n\nconst doSet = async (app, auth, username, newpassword) => {\n  auth.temporaryAccessHash = '';\n  auth.temporaryAccessExpiryEpoch = 0;\n  auth.passwordHash = await app.crypto.hash(\n    newpassword,\n  );\n  await app.datastore.updateJson(\n    userAuthFile(username),\n    auth,\n  );\n};\n\nexport const scorePassword = app => password => apiWrapperSync(\n  app,\n  events.authApi.scorePassword,\n  alwaysAuthorized,\n  { password },\n  _scorePassword, password,\n);\n\nexport const _scorePassword = (password) => {\n  // from https://stackoverflow.com/questions/948172/password-strength-meter\n  // thank you https://stackoverflow.com/users/46617/tm-lv\n\n  let score = 0;\n  if (!password) { return score; }\n\n  // award every unique letter until 5 repetitions\n  const letters = new Object();\n  for (let i = 0; i < password.length; i++) {\n    letters[password[i]] = (letters[password[i]] || 0) + 1;\n    score += 5.0 / letters[password[i]];\n  }\n\n  // bonus points for mixing it up\n  const variations = {\n    digits: /\\d/.test(password),\n    lower: /[a-z]/.test(password),\n    upper: /[A-Z]/.test(password),\n    nonWords: /\\W/.test(password),\n  };\n\n  let variationCount = 0;\n  for (const check in variations) {\n    variationCount += (variations[check] == true) ? 1 : 0;\n  }\n  score += (variationCount - 1) * 10;\n\n  const strengthText = score > 80\n    ? 'strong'\n    : score > 60\n      ? 'good'\n      : score >= 30\n        ? 'weak'\n        : 'very weak';\n\n  return {\n    score: parseInt(score),\n    strengthText,\n  };\n};\n","import { join, some } from 'lodash/fp';\nimport { validateUser } from './validateUser';\nimport { getNewUserAuth } from './getNewUser';\nimport {\n  getLock, isNolock, releaseLock, apiWrapper, events,\n  insensitiveEquals, isNonEmptyString,\n} from '../common';\nimport {\n  USERS_LOCK_FILE, stripUserOfSensitiveStuff,\n  USERS_LIST_FILE, userAuthFile,\n} from './authCommon';\nimport { getTemporaryCode } from './createTemporaryAccess';\nimport { isValidPassword } from './setPassword';\nimport { permission } from './permissions';\nimport { BadRequestError } from '../common/errors';\n\nexport const createUser = app => async (user, password = null) => apiWrapper(\n  app,\n  events.authApi.createUser,\n  permission.createUser.isAuthorized,\n  { user, password },\n  _createUser, app, user, password,\n);\n\nexport const _createUser = async (app, user, password = null) => {\n  const lock = await getLock(\n    app, USERS_LOCK_FILE, 1000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Unable to create user, could not get lock - try again'); }\n\n  const users = await app.datastore.loadJson(USERS_LIST_FILE);\n\n  const userErrors = validateUser(app)([...users, user], user);\n  if (userErrors.length > 0) { throw new BadRequestError(`User is invalid. ${join('; ')(userErrors)}`); }\n\n  const { auth, tempCode, temporaryAccessId } = await getAccess(\n    app, password,\n  );\n  user.tempCode = tempCode;\n  user.temporaryAccessId = temporaryAccessId;\n\n  if (some(u => insensitiveEquals(u.name, user.name))(users)) { \n    throw new BadRequestError('User already exists'); \n  }\n\n  users.push(\n    stripUserOfSensitiveStuff(user),\n  );\n\n  await app.datastore.updateJson(\n    USERS_LIST_FILE,\n    users,\n  );\n\n  try {\n    await app.datastore.createJson(\n      userAuthFile(user.name),\n      auth,\n    );\n  } catch (_) {\n    await app.datastore.updateJson(\n      userAuthFile(user.name),\n      auth,\n    );\n  }\n\n  await releaseLock(app, lock);\n\n  return user;\n};\n\nconst getAccess = async (app, password) => {\n  const auth = getNewUserAuth(app)();\n\n  if (isNonEmptyString(password)) {\n    if (isValidPassword(password)) {\n      auth.passwordHash = await app.crypto.hash(password);\n      auth.temporaryAccessHash = '';\n      auth.temporaryAccessId = '';\n      auth.temporaryAccessExpiryEpoch = 0;\n      return { auth };\n    }\n    throw new BadRequestError('Password does not meet requirements');\n  } else {\n    const tempAccess = await getTemporaryCode(app);\n    auth.temporaryAccessHash = tempAccess.temporaryAccessHash;\n    auth.temporaryAccessExpiryEpoch = tempAccess.temporaryAccessExpiryEpoch;\n    auth.passwordHash = '';\n    return ({\n      auth,\n      tempCode: tempAccess.tempCode,\n      temporaryAccessId: tempAccess.temporaryAccessId,\n    });\n  }\n};\n","import {\n  getLock,\n  isNolock, releaseLock,\n} from '../common/lock';\nimport { USERS_LOCK_FILE, USERS_LIST_FILE, getUserByName } from './authCommon';\nimport { apiWrapper, events } from '../common';\nimport { permission } from './permissions';\nimport { NotFoundError } from '../common/errors';\n\nexport const enableUser = app => async username => apiWrapper(\n  app,\n  events.authApi.enableUser,\n  permission.enableDisableUser.isAuthorized,\n  { username },\n  _enableUser, app, username,\n);\n\nexport const disableUser = app => async username => apiWrapper(\n  app,\n  events.authApi.disableUser,\n  permission.enableDisableUser.isAuthorized,\n  { username },\n  _disableUser, app, username,\n);\n\nexport const _enableUser = async (app, username) => await toggleUser(app, username, true);\n\nexport const _disableUser = async (app, username) => await toggleUser(app, username, false);\n\nconst toggleUser = async (app, username, enabled) => {\n  const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0);\n\n  const actionName = enabled ? 'enable' : 'disable';\n\n  if (isNolock(lock)) { throw new Error(`Could not ${actionName} user - cannot get lock`); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n    const user = getUserByName(users, username);\n    if (!user) { throw new NotFoundError(`Could not find user to ${actionName}`); }\n\n    if (user.enabled === !enabled) {\n      user.enabled = enabled;\n      await app.datastore.updateJson(USERS_LIST_FILE, users);\n    }\n  } finally {\n    releaseLock(app, lock);\n  }\n};\n","export const getNewAccessLevel = () => () => ({\n  name: '',\n  permissions: [],\n  default:false\n});\n","import {\n  values, includes, map, concat, isEmpty, uniqWith, some,\n  flatten, filter,\n} from 'lodash/fp';\nimport { applyRuleSet, makerule } from '../common/validationCommon';\nimport { permissionTypes } from './authCommon';\nimport {\n  $, isSomething, insensitiveEquals,\n  isNonEmptyString, apiWrapperSync, events,\n} from '../common';\nimport { getNode } from '../templateApi/hierarchy';\nimport { alwaysAuthorized } from './permissions';\n\nconst isAllowedType = t => $(permissionTypes, [\n  values,\n  includes(t),\n]);\n\nconst isRecordOrIndexType = t => some(p => p === t)([\n  permissionTypes.CREATE_RECORD,\n  permissionTypes.UPDATE_RECORD,\n  permissionTypes.DELETE_RECORD,\n  permissionTypes.READ_RECORD,\n  permissionTypes.READ_INDEX,\n  permissionTypes.EXECUTE_ACTION,\n]);\n\n\nconst permissionRules = app => ([\n  makerule('type', 'type must be one of allowed types',\n    p => isAllowedType(p.type)),\n  makerule('nodeKey', 'record and index permissions must include a valid nodeKey',\n    p => (!isRecordOrIndexType(p.type))\n             || isSomething(getNode(app.hierarchy, p.nodeKey))),\n]);\n\nconst applyPermissionRules = app => applyRuleSet(permissionRules(app));\n\nconst accessLevelRules = allLevels => ([\n  makerule('name', 'name must be set',\n    l => isNonEmptyString(l.name)),\n  makerule('name', 'access level names must be unique',\n    l => isEmpty(l.name)\n             || filter(a => insensitiveEquals(l.name, a.name))(allLevels).length === 1),\n]);\n\nconst applyLevelRules = allLevels => applyRuleSet(accessLevelRules(allLevels));\n\nexport const validateAccessLevel = app => (allLevels, level) => {\n  const errs = $(level.permissions, [\n    map(applyPermissionRules(app)),\n    flatten,\n    concat(\n      applyLevelRules(allLevels)(level),\n    ),\n  ]);\n\n  return errs;\n};\n\nexport const validateAccessLevels = app => allLevels => apiWrapperSync(\n  app,\n  events.authApi.validateAccessLevels,\n  alwaysAuthorized,\n  { allLevels },\n  _validateAccessLevels, app, allLevels,\n);\n\nexport const _validateAccessLevels = (app, allLevels) => $(allLevels, [\n  map(l => validateAccessLevel(app)(allLevels, l)),\n  flatten,\n  uniqWith((x, y) => x.field === y.field\n                        && x.item === y.item\n                        && x.error === y.error),\n]);\n","import { join, map } from 'lodash/fp';\nimport {\n  getLock, releaseLock, $,\n  isNolock, apiWrapper, events,\n} from '../common';\nimport {\n  ACCESS_LEVELS_LOCK_FILE,\n  ACCESS_LEVELS_FILE,\n} from './authCommon';\nimport { validateAccessLevels } from './validateAccessLevels';\nimport { permission } from './permissions';\n\nexport const saveAccessLevels = app => async accessLevels => apiWrapper(\n  app,\n  events.authApi.saveAccessLevels,\n  permission.writeAccessLevels.isAuthorized,\n  { accessLevels },\n  _saveAccessLevels, app, accessLevels,\n);\n\nexport const _saveAccessLevels = async (app, accessLevels) => {\n  const validationErrors = validateAccessLevels(app)(accessLevels.levels);\n  if (validationErrors.length > 0) {\n    const errs = $(validationErrors, [\n      map(e => e.error),\n      join(', '),\n    ]);\n    throw new Error(\n      `Access Levels Invalid: ${errs}`,\n    );\n  }\n\n  const lock = await getLock(\n    app, ACCESS_LEVELS_LOCK_FILE, 2000, 2,\n  );\n\n  if (isNolock(lock)) { throw new Error('Could not get lock to save access levels'); }\n\n  try {\n    const existing = await app.datastore.loadJson(ACCESS_LEVELS_FILE);\n    if (existing.version !== accessLevels.version) { throw new Error('Access levels have already been updated, since you loaded'); }\n\n    accessLevels.version++;\n\n    app.datastore.updateJson(ACCESS_LEVELS_FILE, accessLevels);\n  } finally {\n    await releaseLock(app, lock);\n  }\n};\n","import {\n  filter, values, each, keys,\n} from 'lodash/fp';\nimport { permission } from './permissions';\nimport {\n  getFlattenedHierarchy,\n  isIndex, isRecord,\n} from '../templateApi/hierarchy';\nimport { $ } from '../common';\n\nexport const generateFullPermissions = (app) => {\n  const allNodes = getFlattenedHierarchy(app.hierarchy);\n  const accessLevel = { permissions: [] };\n\n  const recordNodes = $(allNodes, [\n    filter(isRecord),\n  ]);\n\n  for (const n of recordNodes) {\n    permission.createRecord.add(n.nodeKey(), accessLevel);\n    permission.updateRecord.add(n.nodeKey(), accessLevel);\n    permission.deleteRecord.add(n.nodeKey(), accessLevel);\n    permission.readRecord.add(n.nodeKey(), accessLevel);\n  }\n\n  const indexNodes = $(allNodes, [\n    filter(isIndex),\n  ]);\n\n  for (const n of indexNodes) {\n    permission.readIndex.add(n.nodeKey(), accessLevel);\n  }\n\n  for (const a of keys(app.actions)) {\n    permission.executeAction.add(a, accessLevel);\n  }\n\n  $(permission, [\n    values,\n    filter(p => !p.isNode),\n    each(p => p.add(accessLevel)),\n  ]);\n\n  return accessLevel.permissions;\n};\n","import { difference, map, join } from 'lodash/fp';\nimport {\n  getLock, isNolock, releaseLock, $,\n  apiWrapper, events,\n} from '../common';\nimport {\n  USERS_LOCK_FILE, ACCESS_LEVELS_FILE,\n  getUserByName, USERS_LIST_FILE,\n} from './authCommon';\nimport { permission } from './permissions';\nimport { NotFoundError } from '../common/errors';\n\nexport const setUserAccessLevels = app => async (userName, accessLevels) => apiWrapper(\n  app,\n  events.authApi.setUserAccessLevels,\n  permission.setUserAccessLevels.isAuthorized,\n  { userName, accessLevels },\n  _setUserAccessLevels, app, userName, accessLevels,\n);\n\nexport const _setUserAccessLevels = async (app, username, accessLevels) => {\n  const lock = await getLock(app, USERS_LOCK_FILE, 1000, 1, 0);\n\n  const actualAccessLevels = $(\n    await app.datastore.loadJson(ACCESS_LEVELS_FILE),\n    [\n      l => l.levels,\n      map(l => l.name),\n    ],\n  );\n\n  const missing = difference(accessLevels)(actualAccessLevels);\n  if (missing.length > 0) {\n    throw new Error(`Invalid access levels supplied: ${join(', ', missing)}`);\n  }\n\n  if (isNolock(lock)) { throw new Error('Could set user access levels cannot get lock'); }\n\n  try {\n    const users = await app.datastore.loadJson(USERS_LIST_FILE);\n    const user = getUserByName(users, username);\n    if (!user) { throw new NotFoundError(`Could not find user with ${username}`); }\n\n    user.accessLevels = accessLevels;\n    await app.datastore.updateJson(USERS_LIST_FILE, users);\n  } finally {\n    releaseLock(app, lock);\n  }\n};\n","import {\n  authenticate,\n  authenticateTemporaryAccess,\n} from './authenticate';\nimport { createTemporaryAccess } from './createTemporaryAccess';\nimport { createUser } from './createUser';\nimport { enableUser, disableUser } from './enableUser';\nimport { loadAccessLevels } from './loadAccessLevels';\nimport { getNewAccessLevel } from './getNewAccessLevel';\nimport { getNewUser, getNewUserAuth } from './getNewUser';\nimport { getUsers } from './getUsers';\nimport { isAuthorized } from './isAuthorized';\nimport { saveAccessLevels } from './saveAccessLevels';\nimport {\n  changeMyPassword,\n  scorePassword, setPasswordFromTemporaryCode,\n  isValidPassword,\n} from './setPassword';\nimport { validateUser } from './validateUser';\nimport { validateAccessLevels } from './validateAccessLevels';\nimport { generateFullPermissions } from './generateFullPermissions';\nimport { setUserAccessLevels } from './setUserAccessLevels';\n\nexport const getAuthApi = app => ({\n  authenticate: authenticate(app),\n  authenticateTemporaryAccess: authenticateTemporaryAccess(app),\n  createTemporaryAccess: createTemporaryAccess(app),\n  createUser: createUser(app),\n  loadAccessLevels: loadAccessLevels(app),\n  enableUser: enableUser(app),\n  disableUser: disableUser(app),\n  getNewAccessLevel: getNewAccessLevel(app),\n  getNewUser: getNewUser(app),\n  getNewUserAuth: getNewUserAuth(app),\n  getUsers: getUsers(app),\n  saveAccessLevels: saveAccessLevels(app),\n  isAuthorized: isAuthorized(app),\n  changeMyPassword: changeMyPassword(app),\n  setPasswordFromTemporaryCode: setPasswordFromTemporaryCode(app),\n  scorePassword,\n  isValidPassword: isValidPassword(app),\n  validateUser: validateUser(app),\n  validateAccessLevels: validateAccessLevels(app),\n  generateFullPermissions: () => generateFullPermissions(app),\n  setUserAccessLevels: setUserAccessLevels(app),\n});\n\nexport default getAuthApi;\n","import { permission } from '../authApi/permissions';\nimport { apiWrapperSync } from '../common/apiWrapper';\nimport { events } from '../common/events';\n\nexport const executeAction = app => (actionName, options) => {\n  apiWrapperSync(\n    app,\n    events.actionsApi.execute,\n    permission.executeAction.isAuthorized(actionName),\n    { actionName, options },\n    app.actions[actionName], options,\n  );\n};\n\nexport const _executeAction = (behaviourSources, action, options) => behaviourSources[action.behaviourSource][action.behaviourName](options);\n","import { executeAction } from './execute';\n\nexport const getActionsApi = app => ({\n  execute: executeAction(app),\n});\n\nexport default getActionsApi;\n","import { has } from 'lodash/fp';\n\nconst publish = handlers => async (eventName, context = {}) => {\n  if (!has(eventName)(handlers)) return;\n\n  for (const handler of handlers[eventName]) {\n    await handler(eventName, context);\n  }\n};\n\nconst subscribe = handlers => (eventName, handler) => {\n  if (!has(eventName)(handlers)) {\n    handlers[eventName] = [];\n  }\n  handlers[eventName].push(handler);\n};\n\nexport const createEventAggregator = () => {\n  const handlers = {};\n  const eventAggregator = ({\n    publish: publish(handlers),\n    subscribe: subscribe(handlers),\n  });\n  return eventAggregator;\n};\n\nexport default createEventAggregator;\n","import { retry } from '../common/index';\nimport { NotFoundError } from '../common/errors';\n\nconst createJson = originalCreateFile => async (key, obj, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, key, JSON.stringify(obj));\n\nconst createNewFile = originalCreateFile => async (path, content, retries = 2, delay = 100) => await retry(originalCreateFile, retries, delay, path, content);\n\nconst loadJson = datastore => async (key, retries = 3, delay = 100) => {\n  try {\n    return await retry(JSON.parse, retries, delay, await datastore.loadFile(key));\n  } catch (err) {\n    const newErr = new NotFoundError(err.message);\n    newErr.stack = err.stack;\n    throw(newErr);\n  }\n}\n\nconst updateJson = datastore => async (key, obj, retries = 3, delay = 100) => {\n  try {\n    return await retry(datastore.updateFile, retries, delay, key, JSON.stringify(obj));\n  } catch (err) {\n    const newErr = new NotFoundError(err.message);\n    newErr.stack = err.stack;\n    throw(newErr);\n  }\n}\n\nexport const setupDatastore = (datastore) => {\n  const originalCreateFile = datastore.createFile;\n  datastore.loadJson = loadJson(datastore);\n  datastore.createJson = createJson(originalCreateFile);\n  datastore.updateJson = updateJson(datastore);\n  datastore.createFile = createNewFile(originalCreateFile);\n  if (datastore.createEmptyDb) { delete datastore.createEmptyDb; }\n  return datastore;\n};\n\nexport { createEventAggregator } from './eventAggregator';\n\nexport default setupDatastore;\n","import { \n  compileExpression as cExp, \n  compileCode as cCode \n} from '@nx-js/compiler-util';\n\nexport const compileCode = code => {\n  let func;  \n    \n  try {\n    func = cCode(code);\n  } catch(e) {\n    e.message = `Error compiling code : ${code} : ${e.message}`;\n    throw e;\n  }\n\n  return func;\n}\n\nexport const compileExpression = code => {\n  let func;  \n      \n  try {\n    func = cExp(code);\n  } catch(e) {\n    e.message = `Error compiling expression : ${code} : ${e.message}`;\n    throw e;\n  }\n  \n  return func;\n}\n","import {\n  isFunction, filter, map,\n  uniqBy, keys, difference,\n  join, reduce, find,\n} from 'lodash/fp';\nimport { compileExpression, compileCode } from '../common/compileCode';\nimport { $ } from '../common';\nimport { _executeAction } from './execute';\nimport { BadRequestError, NotFoundError } from '../common/errors';\n\nexport const initialiseActions = (subscribe, behaviourSources, actions, triggers, apis) => {\n  validateSources(behaviourSources, actions);\n  subscribeTriggers(subscribe, behaviourSources, actions, triggers, apis);\n  return createActionsCollection(behaviourSources, actions);\n};\n\nconst createActionsCollection = (behaviourSources, actions) => $(actions, [\n  reduce((all, a) => {\n    all[a.name] = opts => _executeAction(behaviourSources, a, opts);\n    return all;\n  }, {}),\n]);\n\nconst subscribeTriggers = (subscribe, behaviourSources, actions, triggers, apis) => {\n  const createOptions = (optionsCreator, eventContext) => {\n    if (!optionsCreator) return {};\n    const create = compileCode(optionsCreator);\n    return create({ context: eventContext, apis });\n  };\n\n  const shouldRunTrigger = (trigger, eventContext) => {\n    if (!trigger.condition) return true;\n    const shouldRun = compileExpression(trigger.condition);\n    return shouldRun({ context: eventContext });\n  };\n\n  for (let trig of triggers) {\n    subscribe(trig.eventName, async (ev, ctx) => {\n      if (shouldRunTrigger(trig, ctx)) {\n        await _executeAction(\n          behaviourSources,\n          find(a => a.name === trig.actionName)(actions),\n          createOptions(trig.optionsCreator, ctx),\n        );\n      }\n    });\n  }\n};\n\nconst validateSources = (behaviourSources, actions) => {\n  const declaredSources = $(actions, [\n    uniqBy(a => a.behaviourSource),\n    map(a => a.behaviourSource),\n  ]);\n\n  const suppliedSources = keys(behaviourSources);\n\n  const missingSources = difference(\n    declaredSources, suppliedSources,\n  );\n\n  if (missingSources.length > 0) {\n    throw new BadRequestError(`Declared behaviour sources are not supplied: ${join(', ', missingSources)}`);\n  }\n\n  const missingBehaviours = $(actions, [\n    filter(a => !isFunction(behaviourSources[a.behaviourSource][a.behaviourName])),\n    map(a => `Action: ${a.name} : ${a.behaviourSource}.${a.behaviourName}`),\n  ]);\n\n  if (missingBehaviours.length > 0) {\n    throw new NotFoundError(`Missing behaviours: could not find behaviour functions: ${join(', ', missingBehaviours)}`);\n  }\n};\n","import {\n  map, filter, groupBy, split,\n  some, find,\n} from 'lodash/fp';\nimport {\n  LOCK_FILENAME, TRANSACTIONS_FOLDER, idSep, isUpdate,\n  nodeKeyHashFromBuildFolder, isBuildIndexFolder, getTransactionId,\n  isDelete, isCreate,\n} from './transactionsCommon';\nimport {\n  joinKey, $, none, isSomething,\n} from '../common';\nimport { getLastPartInKey, getNodeFromNodeKeyHash } from '../templateApi/hierarchy';\nimport { _load } from '../recordApi/load';\n\nexport const retrieve = async (app) => {\n  const transactionFiles = await app.datastore.getFolderContents(\n    TRANSACTIONS_FOLDER,\n  );\n\n  let transactions = [];\n\n  if (some(isBuildIndexFolder)(transactionFiles)) {\n    const buildIndexFolder = find(isBuildIndexFolder)(transactionFiles);\n\n    transactions = await retrieveBuildIndexTransactions(\n      app,\n      joinKey(TRANSACTIONS_FOLDER, buildIndexFolder),\n    );\n  }\n\n  if (transactions.length > 0) return transactions;\n\n  return await retrieveStandardTransactions(\n    app, transactionFiles,\n  );\n};\n\nconst retrieveBuildIndexTransactions = async (app, buildIndexFolder) => {\n  const childFolders = await app.datastore.getFolderContents(buildIndexFolder);\n  if (childFolders.length === 0) {\n    // cleanup\n    await app.datastore.deleteFolder(buildIndexFolder);\n    return [];\n  }\n\n  const getTransactionFiles = async (childFolderIndex = 0) => {\n    if (childFolderIndex >= childFolders.length) return [];\n\n    const childFolderKey = joinKey(buildIndexFolder, childFolders[childFolderIndex]);\n    const files = await app.datastore.getFolderContents(\n      childFolderKey,\n    );\n\n    if (files.length === 0) {\n      await app.datastore.deleteFolder(childFolderKey);\n      return await getTransactionFiles(childFolderIndex + 1);\n    }\n\n    return { childFolderKey, files };\n  };\n\n  const transactionFiles = await getTransactionFiles();\n\n  if (transactionFiles.files.length === 0) return [];\n\n  const transactions = $(transactionFiles.files, [\n    map(parseTransactionId),\n  ]);\n\n  for (const t of transactions) {\n    const transactionContent = await app.datastore.loadJson(\n      joinKey(\n        transactionFiles.childFolderKey,\n        t.fullId,\n      ),\n    );\n    t.record = await _load(app, transactionContent.recordKey);\n  }\n\n  transactions.indexNode = $(buildIndexFolder, [\n    getLastPartInKey,\n    nodeKeyHashFromBuildFolder,\n    getNodeFromNodeKeyHash(app.hierarchy),\n  ]);\n\n  transactions.folderKey = transactionFiles.childFolderKey;\n\n  return transactions;\n};\n\nconst retrieveStandardTransactions = async (app, transactionFiles) => {\n  const transactionIds = $(transactionFiles, [\n    filter(f => f !== LOCK_FILENAME\n                    && !isBuildIndexFolder(f)),\n    map(parseTransactionId),\n  ]);\n\n  const transactionIdsByRecord = $(transactionIds, [\n    groupBy('recordId'),\n  ]);\n\n  const dedupedTransactions = [];\n\n  const verify = async (t) => {\n    if (t.verified === true) return t;\n\n    const id = getTransactionId(\n      t.recordId,\n      t.transactionType,\n      t.uniqueId,\n    );\n\n    const transaction = await app.datastore.loadJson(\n      joinKey(TRANSACTIONS_FOLDER, id),\n    );\n\n    if (isDelete(t)) {\n      t.record = transaction.record;\n      t.verified = true;\n      return t;\n    }\n\n    const rec = await _load(\n      app,\n      transaction.recordKey,\n    );\n    if (rec.transactionId === id) {\n      t.record = rec;\n      if (transaction.oldRecord) { t.oldRecord = transaction.oldRecord; }\n      t.verified = true;\n    } else {\n      t.verified = false;\n    }\n\n    return t;\n  };\n\n  const pickOne = async (trans, forType) => {\n    const transForType = filter(forType)(trans);\n    if (transForType.length === 1) {\n      const t = await verify(transForType[0]);\n      return (t.verified === true ? t : null);\n    }\n    for (let t of transForType) {\n      t = await verify(t);\n      if (t.verified === true) { return t; }\n    }\n\n    return null;\n  };\n\n  for (const recordId in transactionIdsByRecord) {\n    const transIdsForRecord = transactionIdsByRecord[recordId];\n    if (transIdsForRecord.length === 1) {\n      const t = await verify(transIdsForRecord[0]);\n      if (t.verified) { dedupedTransactions.push(t); }\n      continue;\n    }\n    if (some(isDelete)(transIdsForRecord)) {\n      const t = await verify(find(isDelete)(transIdsForRecord));\n      if (t.verified) { dedupedTransactions.push(t); }\n      continue;\n    }\n    if (some(isUpdate)(transIdsForRecord)) {\n      const upd = await pickOne(transIdsForRecord, isUpdate);\n      if (isSomething(upd) && upd.verified) { dedupedTransactions.push(upd); }\n      continue;\n    }\n    if (some(isCreate)(transIdsForRecord)) {\n      const cre = await pickOne(transIdsForRecord, isCreate);\n      if (isSomething(cre)) { dedupedTransactions.push(cre); }\n      continue;\n    }\n  }\n\n  const duplicates = $(transactionIds, [\n    filter(t => none(ddt => ddt.uniqueId === t.uniqueId)(dedupedTransactions)),\n  ]);\n\n\n  const deletePromises = map(t => app.datastore.deleteFile(\n    joinKey(\n      TRANSACTIONS_FOLDER,\n      getTransactionId(\n        t.recordId,\n        t.transactionType,\n        t.uniqueId,\n      ),\n    ),\n  ))(duplicates);\n\n  await Promise.all(deletePromises);\n\n  return dedupedTransactions;\n};\n\nconst parseTransactionId = (id) => {\n  const splitId = split(idSep)(id);\n  return ({\n    recordId: splitId[0],\n    transactionType: splitId[1],\n    uniqueId: splitId[2],\n    fullId: id,\n  });\n};\n","import { orderBy } from 'lodash';\nimport {\n  reduce, find, includes, flatten, union,\n  filter, each, map,\n} from 'lodash/fp';\nimport {\n  joinKey, splitKey, isNonEmptyString,\n  isNothing, $, isSomething,\n} from '../common';\nimport {\n  getFlattenedHierarchy, getNode, getRecordNodeId,\n  getExactNodeForKey, recordNodeIdIsAllowed,\n  isRecord, isGlobalIndex,\n} from '../templateApi/hierarchy';\nimport { indexTypes } from '../templateApi/indexes';\nimport { getIndexDir } from \"../indexApi/getIndexDir\";\nimport { getRecordInfo} from \"../recordApi/recordInfo\";\n\nexport const getRelevantAncestorIndexes = (hierarchy, record) => {\n  const key = record.key;\n  const keyParts = splitKey(key);\n  const nodeId = getRecordNodeId(key);\n\n  const flatHierarchy = orderBy(getFlattenedHierarchy(hierarchy),\n    [node => node.pathRegx().length],\n    ['desc']);\n\n  const makeindexNodeAndDir_ForAncestorIndex = (indexNode, parentRecordDir) => makeIndexNodeAndDir(indexNode, joinKey(parentRecordDir, indexNode.name));\n\n  const traverseAncestorIndexesInPath = () => reduce((acc, part) => {\n    const currentIndexKey = joinKey(acc.lastIndexKey, part);\n    acc.lastIndexKey = currentIndexKey;\n    const testPathRegx = p => new RegExp(`${p.pathRegx()}$`).test(currentIndexKey);\n    const nodeMatch = find(testPathRegx)(flatHierarchy);\n\n    if (isNothing(nodeMatch)) { return acc; }\n\n    if (!isRecord(nodeMatch)\n                || nodeMatch.indexes.length === 0) { return acc; }\n\n    const indexes = $(nodeMatch.indexes, [\n      filter(i => i.indexType === indexTypes.ancestor\n                        && (i.allowedRecordNodeIds.length === 0\n                         || includes(nodeId)(i.allowedRecordNodeIds))),\n    ]);\n\n    const currentRecordDir = getRecordInfo(hierarchy, currentIndexKey).dir;\n\n    each(v => acc.nodesAndKeys.push(\n      makeindexNodeAndDir_ForAncestorIndex(v, currentRecordDir),\n    ))(indexes);\n\n    return acc;\n  }, { lastIndexKey: '', nodesAndKeys: [] })(keyParts).nodesAndKeys;\n\n  const rootIndexes = $(flatHierarchy, [\n    filter(n => isGlobalIndex(n) && recordNodeIdIsAllowed(n)(nodeId)),\n    map(i => makeIndexNodeAndDir(\n              i, \n              getIndexDir(hierarchy, i.nodeKey()))),\n  ]);\n\n  return union(traverseAncestorIndexesInPath())(rootIndexes);\n};\n\nexport const getRelevantReverseReferenceIndexes = (hierarchy, record) => $(record.key, [\n  getExactNodeForKey(hierarchy),\n  n => n.fields,\n  filter(f => f.type === 'reference'\n                    && isSomething(record[f.name])\n                    && isNonEmptyString(record[f.name].key)),\n  map(f => $(f.typeOptions.reverseIndexNodeKeys, [\n    map(n => ({\n      recordNode: getNode(hierarchy, n),\n      field: f,\n    })),\n  ])),\n  flatten,\n  map(n => makeIndexNodeAndDir(\n    n.recordNode,\n    joinKey(\n      getRecordInfo(hierarchy, record[n.field.name].key).dir, \n      n.recordNode.name),\n  )),\n]);\n\nconst makeIndexNodeAndDir = (indexNode, indexDir) => ({ indexNode, indexDir });\n\nexport default getRelevantAncestorIndexes;\n","  // adapted from https://github.com/dex4er/js-promise-writable\n  // Thank you :) \n  export const promiseWriteableStream = stream => {\n  \n    let _errored;\n  \n    const _errorHandler = err => {\n        _errored = err;\n    };\n\n    stream.on(\"error\", _errorHandler);    \n  \n    const write = chunk => {  \n      let rejected = false;\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err);\n        }\n  \n        if (!stream.writable || stream.closed || stream.destroyed) {\n          return reject(new Error(\"write after end\"));\n        }\n  \n        const writeErrorHandler = err => {\n          _errored = undefined;\n          rejected = true;\n          reject(err);\n        }\n  \n        stream.once(\"error\", writeErrorHandler);\n  \n        const canWrite = stream.write(chunk);\n  \n        stream.removeListener(\"error\", writeErrorHandler);\n  \n        if (canWrite) {\n          if (!rejected) {\n            resolve(chunk.length);\n          }\n        } else {\n          const errorHandler = err => {\n            _errored = undefined;\n            removeListeners();\n            reject(err);\n          }\n  \n          const drainHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const closeHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const finishHandler = () => {\n            removeListeners();\n            resolve(chunk.length);\n          }\n  \n          const removeListeners = () => {\n            stream.removeListener(\"close\", closeHandler);\n            stream.removeListener(\"drain\", drainHandler);\n            stream.removeListener(\"error\", errorHandler);\n            stream.removeListener(\"finish\", finishHandler);\n          }\n  \n          stream.on(\"close\", closeHandler);\n          stream.on(\"drain\", drainHandler);\n          stream.on(\"error\", errorHandler);\n          stream.on(\"finish\", finishHandler);\n        }\n      })\n    }\n  \n    const end = () => {\n  \n      return new Promise((resolve, reject) => {\n        if (_errored) {\n          const err = _errored;\n          _errored = undefined;\n          return reject(err);\n        }\n  \n        if (!stream.writable || stream.closed || stream.destroyed) {\n          return resolve();\n        }\n  \n        const finishHandler = () => {\n          removeListeners();\n          resolve();\n        }\n  \n        const errorHandler = (err) => {\n          _errored = undefined;\n          removeListeners();\n          reject(err);\n        }\n  \n        const removeListeners = () => {\n          stream.removeListener(\"error\", errorHandler);\n          stream.removeListener(\"finish\", finishHandler);\n        }\n  \n        stream.on(\"finish\", finishHandler);\n        stream.on(\"error\", errorHandler);\n  \n        stream.end();\n      })\n    }\n\n    return {write, end};\n  }\n  \n  export default promiseWriteableStream\n  ","import { ensureShardNameIsInShardMap } from './sharding';\nimport { getIndexWriter } from './serializer';\nimport { isShardedIndex, getParentKey } from '../templateApi/hierarchy';\nimport {promiseWriteableStream} from \"./promiseWritableStream\";\nimport {promiseReadableStream} from \"./promiseReadableStream\";\n\nexport const applyToShard = async (hierarchy, store, indexDir,\n  indexNode, indexShardKey, recordsToWrite, keysToRemove) => {\n  const createIfNotExists = recordsToWrite.length > 0;\n  const writer = await getWriter(hierarchy, store, indexDir, indexShardKey, indexNode, createIfNotExists);\n  if (writer === SHARD_DELETED) return;\n\n  await writer.updateIndex(recordsToWrite, keysToRemove);\n  await swapTempFileIn(store, indexShardKey);\n};\n\nconst SHARD_DELETED = 'SHARD_DELETED';\nconst getWriter = async (hierarchy, store, indexDir, indexedDataKey, indexNode, createIfNotExists) => {\n  let readableStream = null;\n\n  if (isShardedIndex(indexNode)) {\n    await ensureShardNameIsInShardMap(store, indexDir, indexedDataKey);\n    if(!await store.exists(indexedDataKey)) {\n      if (await store.exists(getParentKey(indexedDataKey))) {\n        await store.createFile(indexedDataKey, \"\");\n      } else {\n        return SHARD_DELETED;\n      }\n    }\n  }\n\n  try {\n\n    readableStream = promiseReadableStream(\n        await store.readableFileStream(indexedDataKey)\n    );\n\n  } catch (e) {\n\n    if (await store.exists(indexedDataKey)) {\n      throw e;\n    } else {\n      if (createIfNotExists) { \n        if(await store.exists(getParentKey(indexedDataKey))) {\n          await store.createFile(indexedDataKey, '');     \n        } else {\n          return SHARD_DELETED; \n        }\n      } else { \n        return SHARD_DELETED; \n      }\n\n      readableStream = promiseReadableStream(\n          await store.readableFileStream(indexedDataKey)\n      );\n\n    }\n  }\n\n  const writableStream = promiseWriteableStream(\n      await store.writableFileStream(indexedDataKey + \".temp\")\n  );\n\n  return getIndexWriter(\n    hierarchy, indexNode,\n        readableStream, writableStream\n  );\n};\n\nconst swapTempFileIn = async (store, indexedDataKey, isRetry = false) => {\n  const tempFile = `${indexedDataKey}.temp`;\n  try {\n    await store.deleteFile(indexedDataKey);\n  } catch (e) {\n    // ignore failure, incase it has not been created yet\n\n    // if parent folder does not exist, assume that this index\n    // should not be there\n    if(!await store.exists(getParentKey(indexedDataKey))) {\n      return;\n    }\n  }\n  try {\n    await store.renameFile(tempFile, indexedDataKey);\n  } catch (e) {\n    // retrying in case delete failure was for some other reason\n    if (!isRetry) {\n      await swapTempFileIn(store, indexedDataKey, true);\n    } else {\n      throw new Error(\"Failed to swap in index filed: \" + e.message);\n    }\n  }\n};\n","import {\n  filter, map, isUndefined, includes,\n  flatten, intersectionBy,\n  isEqual, pull, keys,\n  differenceBy, difference,\n} from 'lodash/fp';\nimport { union } from 'lodash';\nimport {\n  getRelevantAncestorIndexes,\n  getRelevantReverseReferenceIndexes,\n} from '../indexing/relevant';\nimport { evaluate } from '../indexing/evaluate';\nimport {\n  $, isSomething,\n  isNonEmptyArray, joinKey,\n  isNonEmptyString,\n} from '../common';\nimport { getIndexedDataKey } from '../indexing/sharding';\nimport {\n  isUpdate, isCreate,\n  isDelete, isBuildIndex,\n} from './transactionsCommon';\nimport { applyToShard } from '../indexing/apply';\nimport {\n  getActualKeyOfParent,\n  isGlobalIndex, fieldReversesReferenceToIndex, isReferenceIndex,\n  getExactNodeForKey,\n} from '../templateApi/hierarchy';\nimport { getRecordInfo } from \"../recordApi/recordInfo\";\nimport { getIndexDir } from '../indexApi/getIndexDir';\n\nexport const executeTransactions = app => async (transactions) => {\n  const recordsByShard = mappedRecordsByIndexShard(app.hierarchy, transactions);\n\n  for (const shard of keys(recordsByShard)) {\n    await applyToShard(\n      app.hierarchy, app.datastore,\n      recordsByShard[shard].indexDir,\n      recordsByShard[shard].indexNode,\n      shard,\n      recordsByShard[shard].writes,\n      recordsByShard[shard].removes,\n    );\n  }\n};\n\nconst mappedRecordsByIndexShard = (hierarchy, transactions) => {\n  const updates = getUpdateTransactionsByShard(\n    hierarchy, transactions,\n  );\n\n  const created = getCreateTransactionsByShard(\n    hierarchy, transactions,\n  );\n  const deletes = getDeleteTransactionsByShard(\n    hierarchy, transactions,\n  );\n\n  const indexBuild = getBuildIndexTransactionsByShard(\n    hierarchy,\n    transactions,\n  );\n\n  const toRemove = [\n    ...deletes,\n    ...updates.toRemove,\n  ];\n\n  const toWrite = [\n    ...created,\n    ...updates.toWrite,\n    ...indexBuild,\n  ];\n\n  const transByShard = {};\n\n  const initialiseShard = (t) => {\n    if (isUndefined(transByShard[t.indexShardKey])) {\n      transByShard[t.indexShardKey] = {\n        writes: [],\n        removes: [],\n        indexDir: t.indexDir,\n        indexNodeKey: t.indexNode.nodeKey(),\n        indexNode: t.indexNode,\n      };\n    }\n  };\n\n  for (const trans of toWrite) {\n    initialiseShard(trans);\n    transByShard[trans.indexShardKey].writes.push(\n      trans.mappedRecord.result,\n    );\n  }\n\n  for (const trans of toRemove) {\n    initialiseShard(trans);\n    transByShard[trans.indexShardKey].removes.push(\n      trans.mappedRecord.result.key,\n    );\n  }\n\n  return transByShard;\n};\n\nconst getUpdateTransactionsByShard = (hierarchy, transactions) => {\n  const updateTransactions = $(transactions, [filter(isUpdate)]);\n\n  const evaluateIndex = (record, indexNodeAndPath) => {\n    const mappedRecord = evaluate(record)(indexNodeAndPath.indexNode);\n    return ({\n      mappedRecord,\n      indexNode: indexNodeAndPath.indexNode,\n      indexDir: indexNodeAndPath.indexDir,\n      indexShardKey: getIndexedDataKey(\n        indexNodeAndPath.indexNode,\n        indexNodeAndPath.indexDir,\n        mappedRecord.result,\n      ),\n    });\n  };\n\n  const getIndexNodesToApply = indexFilter => (t, indexes) => $(indexes, [\n    map(n => ({\n      old: evaluateIndex(t.oldRecord, n),\n      new: evaluateIndex(t.record, n),\n    })),\n    filter(indexFilter),\n  ]);\n\n  const toRemoveFilter = (n, isUnreferenced) => n.old.mappedRecord.passedFilter === true\n        && (n.new.mappedRecord.passedFilter === false\n            || isUnreferenced);\n\n  const toAddFilter = (n, isNewlyReferenced) => (n.old.mappedRecord.passedFilter === false\n        || isNewlyReferenced)\n        && n.new.mappedRecord.passedFilter === true;\n\n  const toUpdateFilter = n => n.new.mappedRecord.passedFilter === true\n        && n.old.mappedRecord.passedFilter === true\n        && !isEqual(n.old.mappedRecord.result,\n          n.new.mappedRecord.result);\n\n  const toRemove = [];\n  const toWrite = [];\n\n  for (const t of updateTransactions) {\n    const ancestorIdxs = getRelevantAncestorIndexes(\n      hierarchy, t.record,\n    );\n\n    const referenceChanges = diffReverseRefForUpdate(\n      hierarchy, t.oldRecord, t.record,\n    );\n\n    // old records to remove (filtered out)\n    const filteredOut_toRemove = union(\n      getIndexNodesToApply(toRemoveFilter)(t, ancestorIdxs),\n      // still referenced - check filter\n      getIndexNodesToApply(toRemoveFilter)(t, referenceChanges.notChanged),\n      // un referenced - remove if in there already\n      getIndexNodesToApply(n => toRemoveFilter(n, true))(t, referenceChanges.unReferenced),\n    );\n\n    // new records to add (filtered in)\n    const filteredIn_toAdd = union(\n      getIndexNodesToApply(toAddFilter)(t, ancestorIdxs),\n      // newly referenced - check filter\n      getIndexNodesToApply(n => toAddFilter(n, true))(t, referenceChanges.newlyReferenced),\n      // reference unchanged - rerun filter in case something else changed\n      getIndexNodesToApply(toAddFilter)(t, referenceChanges.notChanged),\n    );\n\n    const changed = union(\n      getIndexNodesToApply(toUpdateFilter)(t, ancestorIdxs),\n      // still referenced - recheck filter\n      getIndexNodesToApply(toUpdateFilter)(t, referenceChanges.notChanged),\n    );\n\n    const shardKeyChanged = $(changed, [\n      filter(c => c.old.indexShardKey !== c.new.indexShardKey),\n    ]);\n\n    const changedInSameShard = $(shardKeyChanged, [\n      difference(changed),\n    ]);\n\n    for (const res of shardKeyChanged) {\n      pull(res)(changed);\n      filteredOut_toRemove.push(res);\n      filteredIn_toAdd.push(res);\n    }\n\n    toRemove.push(\n      $(filteredOut_toRemove, [\n        map(i => i.old),\n      ]),\n    );\n\n    toWrite.push(\n      $(filteredIn_toAdd, [\n        map(i => i.new),\n      ]),\n    );\n\n    toWrite.push(\n      $(changedInSameShard, [\n        map(i => i.new),\n      ]),\n    );\n  }\n\n  return ({\n    toRemove: flatten(toRemove),\n    toWrite: flatten(toWrite),\n  });\n};\n\nconst getBuildIndexTransactionsByShard = (hierarchy, transactions) => {\n  const buildTransactions = $(transactions, [filter(isBuildIndex)]);\n  if (!isNonEmptyArray(buildTransactions)) return [];\n  const indexNode = transactions.indexNode;\n\n  const getIndexDirs = (t) => {\n    if (isGlobalIndex(indexNode)) {\n      return [indexNode.nodeKey()];\n    }\n\n    if (isReferenceIndex(indexNode)) {\n      const recordNode = getExactNodeForKey(hierarchy)(t.record.key);\n      const refFields = $(recordNode.fields, [\n        filter(fieldReversesReferenceToIndex(indexNode)),\n      ]);\n      const indexDirs = [];\n      for (const refField of refFields) {\n        const refValue = t.record[refField.name];\n        if (isSomething(refValue)\n                   && isNonEmptyString(refValue.key)) {\n          const indexDir = joinKey(\n            getRecordInfo(hierarchy, refValue.key).dir,\n            indexNode.name,\n          );\n\n          if (!includes(indexDir)(indexDirs)) { indexDirs.push(indexDir); }\n        }\n      }\n      return indexDirs;\n    }\n\n    const indexKey = joinKey(\n      getActualKeyOfParent(\n        indexNode.parent().nodeKey(),\n        t.record.key,\n      ),\n      indexNode.name,\n    );\n\n    return [getIndexDir(hierarchy, indexKey)];\n  };\n\n  return $(buildTransactions, [\n    map((t) => {\n      const mappedRecord = evaluate(t.record)(indexNode);\n      if (!mappedRecord.passedFilter) return null;\n      const indexDirs = getIndexDirs(t);\n      return $(indexDirs, [\n        map(indexDir => ({\n          mappedRecord,\n          indexNode,\n          indexDir,\n          indexShardKey: getIndexedDataKey(\n            indexNode,\n            indexDir,\n            mappedRecord.result,\n          ),\n        })),\n      ]);\n    }),\n    flatten,\n    filter(isSomething),\n  ]);\n};\n\nconst get_Create_Delete_TransactionsByShard = pred => (hierarchy, transactions) => {\n  const createTransactions = $(transactions, [filter(pred)]);\n\n  const getIndexNodesToApply = (t, indexes) => $(indexes, [\n    map((n) => {\n      const mappedRecord = evaluate(t.record)(n.indexNode);\n      return ({\n        mappedRecord,\n        indexNode: n.indexNode,\n        indexDir: n.indexDir,\n        indexShardKey: getIndexedDataKey(\n          n.indexNode,\n          n.indexDir,\n          mappedRecord.result,\n        ),\n      });\n    }),\n    filter(n => n.mappedRecord.passedFilter),\n  ]);\n\n  const allToApply = [];\n\n  for (const t of createTransactions) {\n    const ancestorIdxs = getRelevantAncestorIndexes(hierarchy, t.record);\n    const reverseRef = getRelevantReverseReferenceIndexes(hierarchy, t.record);\n\n    allToApply.push(\n      getIndexNodesToApply(t, ancestorIdxs),\n    );\n    allToApply.push(\n      getIndexNodesToApply(t, reverseRef),\n    );\n  }\n\n  return flatten(allToApply);\n};\n\nconst getDeleteTransactionsByShard = get_Create_Delete_TransactionsByShard(isDelete);\n\nconst getCreateTransactionsByShard = get_Create_Delete_TransactionsByShard(isCreate);\n\nconst diffReverseRefForUpdate = (appHierarchy, oldRecord, newRecord) => {\n  const oldIndexes = getRelevantReverseReferenceIndexes(\n    appHierarchy, oldRecord,\n  );\n  const newIndexes = getRelevantReverseReferenceIndexes(\n    appHierarchy, newRecord,\n  );\n\n  const unReferenced = differenceBy(\n    i => i.indexDir,\n    oldIndexes, newIndexes,\n  );\n\n  const newlyReferenced = differenceBy(\n    i => i.indexDir,\n    newIndexes, oldIndexes,\n  );\n\n  const notChanged = intersectionBy(\n    i => i.indexDir,\n    newIndexes, oldIndexes,\n  );\n\n  return {\n    unReferenced,\n    newlyReferenced,\n    notChanged,\n  };\n};\n","import { map } from 'lodash/fp';\nimport { retrieve } from './retrieve';\nimport { executeTransactions } from './execute';\nimport {\n  $, joinKey, getLock, isNolock, releaseLock,\n} from '../common';\nimport {\n  LOCK_FILE_KEY, TRANSACTIONS_FOLDER,\n  timeoutMilliseconds, getTransactionId,\n  maxLockRetries,\n} from './transactionsCommon';\n\nexport const cleanup = async (app) => {\n  const lock = await getTransactionLock(app);\n  if (isNolock(lock)) return;\n\n  try {\n    const transactions = await retrieve(app);\n    if (transactions.length > 0) {\n      await executeTransactions(app)(transactions);\n\n      const folder = transactions.folderKey\n        ? transactions.folderKey\n        : TRANSACTIONS_FOLDER;\n\n      const deleteFiles = $(transactions, [\n        map(t => joinKey(\n          folder,\n          getTransactionId(\n            t.recordId, t.transactionType,\n            t.uniqueId,\n          ),\n        )),\n        map(app.datastore.deleteFile),\n      ]);\n\n      await Promise.all(deleteFiles);\n    }\n  } finally {\n    await releaseLock(app, lock);\n  }\n};\n\nconst getTransactionLock = async app => await getLock(\n  app, LOCK_FILE_KEY,\n  timeoutMilliseconds, maxLockRetries,\n);\n","import { filter } from 'lodash/fp';\nimport { configFolder, appDefinitionFile, $ } from '../common';\nimport { TRANSACTIONS_FOLDER } from '../transactions/transactionsCommon';\nimport { AUTH_FOLDER, USERS_LIST_FILE, ACCESS_LEVELS_FILE } from '../authApi/authCommon';\nimport { initialiseRootCollections } from '../collectionApi/initialise';\nimport { initialiseIndex } from '../indexing/initialiseIndex';\nimport { getFlattenedHierarchy, isGlobalIndex, isSingleRecord } from '../templateApi/hierarchy';\nimport { _getNew } from \"../recordApi/getNew\";\nimport { _save } from \"../recordApi/save\";\n\nexport const initialiseData = async (datastore, applicationDefinition, accessLevels) => {\n  await datastore.createFolder(configFolder);\n  await datastore.createJson(appDefinitionFile, applicationDefinition);\n\n  await initialiseRootCollections(datastore, applicationDefinition.hierarchy);\n  await initialiseRootIndexes(datastore, applicationDefinition.hierarchy);\n\n  await datastore.createFolder(TRANSACTIONS_FOLDER);\n\n  await datastore.createFolder(AUTH_FOLDER);\n\n  await datastore.createJson(USERS_LIST_FILE, []);\n\n  await datastore.createJson(\n    ACCESS_LEVELS_FILE, \n    accessLevels ? accessLevels : { version: 0, levels: [] });\n\n  await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy);\n};\n\nconst initialiseRootIndexes = async (datastore, hierarchy) => {\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n  const globalIndexes = $(flathierarchy, [\n    filter(isGlobalIndex),\n  ]);\n\n  for (const index of globalIndexes) {\n    if (!await datastore.exists(index.nodeKey())) { \n      await initialiseIndex(datastore, '', index); \n    }\n  }\n};\n\nconst initialiseRootSingleRecords = async (datastore, hierarchy) => {\n  const app = { \n    publish:()=>{},\n    cleanupTransactions: () => {},\n    datastore, hierarchy \n  };\n\n  const flathierarchy = getFlattenedHierarchy(hierarchy);\n  const singleRecords = $(flathierarchy, [\n    filter(isSingleRecord),\n  ]);\n\n  for (let record of singleRecords) {\n    await datastore.createFolder(record.nodeKey());\n    const result = _getNew(record, \"\");\n    await _save(app,result);\n  }\n};\n","import { isNothing } from '../common';\n\nexport const getDatabaseManager = databaseManager => ({\n  createEmptyMasterDb: createEmptyMasterDb(databaseManager),\n  createEmptyInstanceDb: createEmptyInstanceDb(databaseManager),\n  getInstanceDbRootConfig: databaseManager.getInstanceDbRootConfig,\n  masterDatastoreConfig: getMasterDatastoreConfig(databaseManager),\n  getInstanceDatastoreConfig: getInstanceDatastoreConfig(databaseManager),\n});\n\nconst getMasterDatastoreConfig = databaseManager => databaseManager.getDatastoreConfig('master');\n\nconst getInstanceDatastoreConfig = databaseManager => (applicationId, instanceId) => databaseManager.getDatastoreConfig(\n  applicationId, instanceId,\n);\n\nconst createEmptyMasterDb = databaseManager => async () => await databaseManager.createEmptyDb('master');\n\nconst createEmptyInstanceDb = databaseManager => async (applicationId, instanceId) => {\n  if (isNothing(applicationId)) { throw new Error('CreateDb: application id not supplied'); }\n  if (isNothing(instanceId)) { throw new Error('CreateDb: instance id not supplied'); }\n\n  return await databaseManager.createEmptyDb(\n    applicationId,\n    instanceId,\n  );\n};\n","import getRecordApi from \"./recordApi\";\nimport getCollectionApi from \"./collectionApi\";\nimport getIndexApi from \"./indexApi\";\nimport getTemplateApi from \"./templateApi\";\nimport getAuthApi from \"./authApi\";\nimport getActionsApi from \"./actionsApi\";\nimport {setupDatastore, createEventAggregator} from \"./appInitialise\";\nimport {initialiseActions} from \"./actionsApi/initialise\"\nimport {isSomething} from \"./common\";\nimport {cleanup} from \"./transactions/cleanup\";\nimport {generateFullPermissions} from \"./authApi/generateFullPermissions\";\nimport {getApplicationDefinition} from \"./templateApi/getApplicationDefinition\";\nimport common from \"./common\";\nimport {getBehaviourSources} from \"./templateApi/getBehaviourSources\";\nimport hierarchy from \"./templateApi/hierarchy\";\n\nexport const getAppApis = async (store, behaviourSources = null, \n                                cleanupTransactions = null, \n                                getEpochTime = null,\n                                crypto = null,\n                                appDefinition = null) => {\n\n    store = setupDatastore(store);\n\n    if(!appDefinition)\n        appDefinition = await getApplicationDefinition(store)();\n\n    if(!behaviourSources)\n        behaviourSources = await getBehaviourSources(store);\n\n    const eventAggregator = createEventAggregator();\n\n    const app = {\n        datastore:store,\n        crypto,\n        publish:eventAggregator.publish,\n        hierarchy:appDefinition.hierarchy,\n        actions:appDefinition.actions\n    };\n\n    const templateApi = getTemplateApi(app);    \n\n    app.cleanupTransactions = isSomething(cleanupTransactions) \n                              ? cleanupTransactions\n                              : async () => await cleanup(app);\n\n    app.getEpochTime = isSomething(getEpochTime)\n                       ? getEpochTime\n                       : async () => (new Date()).getTime();\n\n    const recordApi = getRecordApi(app);\n    const collectionApi = getCollectionApi(app);\n    const indexApi = getIndexApi(app);\n    const authApi = getAuthApi(app);\n    const actionsApi = getActionsApi(app);\n\n    const authenticateAs = async (username, password) => {\n        app.user = await authApi.authenticate(username, password);\n    };\n\n    const withFullAccess = () => \n        userWithFullAccess(app);    \n\n    const asUser = (user) => {\n        app.user = user\n    };    \n\n    let apis = {\n        recordApi, \n        templateApi,\n        collectionApi,\n        indexApi,\n        authApi,\n        actionsApi,\n        subscribe: eventAggregator.subscribe,\n        authenticateAs,\n        withFullAccess,\n        asUser\n    };\n\n    apis.actions = initialiseActions(\n        eventAggregator.subscribe,\n        behaviourSources,\n        appDefinition.actions,\n        appDefinition.triggers,\n        apis);\n\n\n    return apis;\n};\n\nexport const userWithFullAccess = (app) => {\n    app.user = {\n        name: \"app\",\n        permissions : generateFullPermissions(app),\n        isUser:false,\n        temp:false\n    }\n    return app.user;\n};\n\nexport {events, eventsList} from \"./common/events\";\nexport {getTemplateApi} from \"./templateApi\";\nexport {getRecordApi} from \"./recordApi\";\nexport {getCollectionApi} from \"./collectionApi\";\nexport {getAuthApi} from \"./authApi\";\nexport {getIndexApi} from \"./indexApi\";\nexport {setupDatastore} from \"./appInitialise\";\nexport {getActionsApi} from \"./actionsApi\";\nexport {initialiseData} from \"./appInitialise/initialiseData\";\nexport {getDatabaseManager} from \"./appInitialise/databaseManager\";\nexport {hierarchy};\nexport {common};\n\nexport default getAppApis;"],"names":["union","reduce","generate","isUndefined","cloneDeep","split","flow","trim","replace","isArray","filter","isNull","join","dropRight","takeRight","head","isNaN","isEmpty","constant","some","isString","tail","includes","startsWith","findIndex","isInteger","isDate","toNumber","map","compileExpression","compileCode","keys","isFunction","countBy","last","find","take","first","intersection","has","merge","mapValues","makerule","isBoolean","options","typeConstraints","isNumber","isObjectLike","assign","all","getDefaultOptions","validateTypeConstraints","isObject","clone","values","keyBy","orderBy","flatten","concat","reverse","global","base64.fromByteArray","ieee754.read","ieee754.write","base64.toByteArray","read","difference","Buffer","readIndex","each","_","deleteRecord","validate","max","defaultCase","every","uniqBy","api","createTemporaryAccess","createUser","uniqWith","setUserAccessLevels","executeAction","cCode","cExp","groupBy","isEqual","pull","differenceBy","intersectionBy"],"mappings":"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"} diff --git a/packages/core/rollup.config.js b/packages/core/rollup.config.js index eb1eafb60e..67a0b8b14d 100644 --- a/packages/core/rollup.config.js +++ b/packages/core/rollup.config.js @@ -59,7 +59,7 @@ export default { external: [ "lodash", "lodash/fp", "date-fns", "lunr", "safe-buffer", "shortid", - "@nx-js/compiler-util" + "@nx-js/compiler-util", "bcryptjs" ] }; diff --git a/packages/server/appPackages/testApp/yarn.lock b/packages/server/appPackages/testApp/yarn.lock index 47cc20a767..6471f44f81 100644 --- a/packages/server/appPackages/testApp/yarn.lock +++ b/packages/server/appPackages/testApp/yarn.lock @@ -3,22 +3,28 @@ "@budibase/client@file:../../../client": - version "0.0.15" + version "0.0.16" dependencies: "@nx-js/compiler-util" "^2.0.0" + bcryptjs "^2.4.3" lodash "^4.17.15" lunr "^2.3.5" shortid "^2.2.8" svelte "^3.9.2" "@budibase/standard-components@file:../../../standard-components": - version "0.0.15" + version "0.0.16" "@nx-js/compiler-util@^2.0.0": version "2.0.0" resolved "https://registry.yarnpkg.com/@nx-js/compiler-util/-/compiler-util-2.0.0.tgz#c74c12165fa2f017a292bb79af007e8fce0af297" integrity sha512-AxSQbwj9zqt8DYPZ6LwZdytqnwfiOEdcFdq4l8sdjkZmU2clTht7RDLCI8xvkp7KqgcNaOGlTeCM55TULWruyQ== +bcryptjs@^2.4.3: + version "2.4.3" + resolved "https://registry.yarnpkg.com/bcryptjs/-/bcryptjs-2.4.3.tgz#9ab5627b93e60621ff7cdac5da9733027df1d0cb" + integrity sha1-mrVie5PmBiH/fNrF2pczAn3x0Ms= + lodash@^4.17.15: version "4.17.15" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.15.tgz#b447f6670a0455bbfeedd11392eff330ea097548" diff --git a/packages/server/yarn.lock b/packages/server/yarn.lock index c99e0e0cf7..f4ad571cdd 100644 --- a/packages/server/yarn.lock +++ b/packages/server/yarn.lock @@ -131,29 +131,6 @@ lodash "^4.17.13" to-fast-properties "^2.0.0" -"@budibase/client@^0.0.16": - version "0.0.16" - resolved "https://registry.yarnpkg.com/@budibase/client/-/client-0.0.16.tgz#4eef9373816448e99cafd2714f417c6610af5e69" - integrity sha512-fx4ptePj7+IehM37xdNPHdu5jEUgAFmDx23jI0yb4sI6Z5U4gxH10FZYyoJ/A9KdzmShsIfgrmudV5ffvoehdg== - dependencies: - "@nx-js/compiler-util" "^2.0.0" - lodash "^4.17.15" - lunr "^2.3.5" - shortid "^2.2.8" - svelte "^3.9.2" - -"@budibase/core@^0.0.16": - version "0.0.16" - resolved "https://registry.yarnpkg.com/@budibase/core/-/core-0.0.16.tgz#efff16876f906b2aa59803c3312ec7593664b623" - integrity sha512-DvzfurHHp9KkSjkvbGbKsVczR5ne38bMLRA2hHEJxAmC0Tshld06cEq7HMy2BmPb6kaC1URYHlFs/gPhW2cSFQ== - dependencies: - "@nx-js/compiler-util" "^2.0.0" - date-fns "^1.29.0" - lodash "^4.17.13" - lunr "^2.3.5" - safe-buffer "^5.1.2" - shortid "^2.2.8" - "@cnakazawa/watch@^1.0.3": version "1.0.3" resolved "https://registry.yarnpkg.com/@cnakazawa/watch/-/watch-1.0.3.tgz#099139eaec7ebf07a27c1786a3ff64f39464d2ef" @@ -322,11 +299,6 @@ path-to-regexp "^1.1.1" urijs "^1.19.0" -"@nx-js/compiler-util@^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@nx-js/compiler-util/-/compiler-util-2.0.0.tgz#c74c12165fa2f017a292bb79af007e8fce0af297" - integrity sha512-AxSQbwj9zqt8DYPZ6LwZdytqnwfiOEdcFdq4l8sdjkZmU2clTht7RDLCI8xvkp7KqgcNaOGlTeCM55TULWruyQ== - "@types/babel__core@^7.1.0": version "7.1.2" resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.2.tgz#608c74f55928033fce18b99b213c16be4b3d114f" @@ -1073,11 +1045,6 @@ data-urls@^1.0.0: whatwg-mimetype "^2.2.0" whatwg-url "^7.0.0" -date-fns@^1.29.0: - version "1.30.1" - resolved "https://registry.yarnpkg.com/date-fns/-/date-fns-1.30.1.tgz#2e71bf0b119153dbb4cc4e88d9ea5acfb50dc05c" - integrity sha512-hBSVCvSmWC+QypYObzwGOd9wqdDpOt+0wl0KbU+R+uuZBS1jN8VsD1ss3irQDknRj5NvxiTF6oj/nDRnN/UQNw== - debug@^2.2.0, debug@^2.3.3: version "2.6.9" resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" @@ -2785,7 +2752,7 @@ lodash.sortby@^4.7.0: resolved "https://registry.yarnpkg.com/lodash.sortby/-/lodash.sortby-4.7.0.tgz#edd14c824e2cc9c1e0b0a1b42bb5210516a42438" integrity sha1-7dFMgk4sycHgsKG0K7UhBRakJDg= -lodash@^4.17.11, lodash@^4.17.13, lodash@^4.17.15: +lodash@^4.17.11, lodash@^4.17.13: version "4.17.15" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.15.tgz#b447f6670a0455bbfeedd11392eff330ea097548" integrity sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A== @@ -2810,11 +2777,6 @@ lru-cache@^4.0.1: pseudomap "^1.0.2" yallist "^2.1.2" -lunr@^2.3.5: - version "2.3.8" - resolved "https://registry.yarnpkg.com/lunr/-/lunr-2.3.8.tgz#a8b89c31f30b5a044b97d2d28e2da191b6ba2072" - integrity sha512-oxMeX/Y35PNFuZoHp+jUj5OSEmLCaIH4KTFJh7a93cHBoFmpw2IoPs22VIz7vyO2YUnx2Tn9dzIwO2P/4quIRg== - make-dir@^1.0.0: version "1.3.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-1.3.0.tgz#79c1033b80515bd6d24ec9933e860ca75ee27f0c" @@ -2976,11 +2938,6 @@ nan@^2.12.1: resolved "https://registry.yarnpkg.com/nan/-/nan-2.14.0.tgz#7818f722027b2459a86f0295d434d1fc2336c52c" integrity sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg== -nanoid@^2.1.0: - version "2.1.8" - resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-2.1.8.tgz#2dbb0224231b246e3b4c819de7bfea6384dabf08" - integrity sha512-g1z+n5s26w0TGKh7gjn7HCqurNKMZWzH08elXzh/gM/csQHd/UqDV6uxMghQYg9IvqRPm1QpeMk50YMofHvEjQ== - nanomatch@^1.2.9: version "1.2.13" resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" @@ -3816,13 +3773,6 @@ shellwords@^0.1.1: resolved "https://registry.yarnpkg.com/shellwords/-/shellwords-0.1.1.tgz#d6b9181c1a48d397324c84871efbcfc73fc0654b" integrity sha512-vFwSUfQvqybiICwZY5+DAWIPLKsWO31Q91JSKl3UYv+K5c2QRPzn0qzec6QPu1Qc9eHYItiP3NdJqNVqetYAww== -shortid@^2.2.8: - version "2.2.15" - resolved "https://registry.yarnpkg.com/shortid/-/shortid-2.2.15.tgz#2b902eaa93a69b11120373cd42a1f1fe4437c122" - integrity sha512-5EaCy2mx2Jgc/Fdn9uuDuNIIfWBpzY4XIlhoqtXF6qsf+/+SGZ+FxDdX/ZsMZiWupIWNqAEmiNY4RC+LSmCeOw== - dependencies: - nanoid "^2.1.0" - signal-exit@^3.0.0, signal-exit@^3.0.2: version "3.0.2" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.2.tgz#b5fdc08f1287ea1178628e415e25132b73646c6d" @@ -4100,11 +4050,6 @@ supports-color@^6.1.0: dependencies: has-flag "^3.0.0" -svelte@^3.9.2: - version "3.16.7" - resolved "https://registry.yarnpkg.com/svelte/-/svelte-3.16.7.tgz#9ade80a4bbbac95595c676dd817222f632fa2c07" - integrity sha512-egrva1UklB1n7KAv179IhDpQzMGAvubJUlOQ9PitmmZmAfrCUEgrQnx2vPxn2s+mGV3aYegXvJ/yQ35N2SfnYQ== - symbol-tree@^3.2.2: version "3.2.4" resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2"