UNPKG

@grnsft/if

Version:

Impact Framework

108 lines 17.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.MockObservations = void 0; const luxon_1 = require("luxon"); const zod_1 = require("zod"); const interfaces_1 = require("@grnsft/if-core/interfaces"); const utils_1 = require("@grnsft/if-core/utils"); const validations_1 = require("../../../common/util/validations"); const config_1 = require("../../config"); const common_generator_1 = require("./helpers/common-generator"); const rand_int_generator_1 = require("./helpers/rand-int-generator"); const { ConfigError } = utils_1.ERRORS; const { MISSING_CONFIG } = config_1.STRINGS; exports.MockObservations = (0, interfaces_1.PluginFactory)({ configValidation: (config) => { if (!config || !Object.keys(config)?.length) { throw new ConfigError(MISSING_CONFIG); } const schema = zod_1.z.object({ 'timestamp-from': zod_1.z.string(), 'timestamp-to': zod_1.z.string(), duration: zod_1.z.number().gt(0), components: zod_1.z.array(zod_1.z.record(zod_1.z.string())), generators: zod_1.z.object({ common: zod_1.z.record(zod_1.z.string().or(zod_1.z.number())), randint: zod_1.z.record(zod_1.z.object({ min: zod_1.z.number(), max: zod_1.z.number() })), }), }); return (0, validations_1.validate)(schema, config); }, implementation: async (inputs, config) => { const { duration, timeBuckets, components, generators } = generateParamsFromConfig(config); const generatorToHistory = new Map(); generators.forEach(generator => { generatorToHistory.set(generator, []); }); const defaults = inputs && inputs[0]; return Object.entries(components).reduce((acc, item) => { const component = item[1]; timeBuckets.forEach(timeBucket => { const observation = createObservation({ duration, component, timeBucket, generators }, generatorToHistory); acc.push(Object.assign({}, defaults, observation)); }); return acc; }, []); }, }); /** * Configures the MockObservations Plugin for IF */ const generateParamsFromConfig = (config) => { const { 'timestamp-from': timestampFrom, 'timestamp-to': timestampTo, duration, generators, components, } = config; const convertedTimestampFrom = luxon_1.DateTime.fromISO(timestampFrom, { zone: 'UTC', }); const convertedTimestampTo = luxon_1.DateTime.fromISO(timestampTo, { zone: 'UTC' }); return { duration, timeBuckets: createTimeBuckets(convertedTimestampFrom, convertedTimestampTo, duration), generators: createGenerators(generators), components, }; }; /* * Creates time buckets based on start time, end time and duration of each bucket. */ const createTimeBuckets = (timestampFrom, timestampTo, duration, timeBuckets = []) => { if (timestampFrom < timestampTo || timestampFrom.plus(luxon_1.Duration.fromObject({ seconds: duration })) < timestampTo) { return createTimeBuckets(timestampFrom.plus(luxon_1.Duration.fromObject({ seconds: duration })), timestampTo, duration, [...timeBuckets, timestampFrom]); } return timeBuckets; }; /* * Creates generators based on a given config */ const createGenerators = (generatorsConfig) => { const createCommonGenerator = (config) => [ (0, common_generator_1.CommonGenerator)(config), ]; const createRandIntGenerators = (config) => Object.entries(config).map(([fieldToPopulate, value]) => (0, rand_int_generator_1.RandIntGenerator)(fieldToPopulate, value)); return Object.entries(generatorsConfig).flatMap(([key, value]) => key === 'randint' ? createRandIntGenerators(value).flat() : createCommonGenerator(value)); }; /* * Creates time buckets based on start time, end time and duration of each bucket. */ const createObservation = (observationParams, generatorToHistory) => { const { duration, component, timeBucket, generators } = observationParams; const timestamp = timeBucket.toISO(); const generateObservation = (generator) => { const history = generatorToHistory.get(generator) || []; const generated = generator.next(history); generatorToHistory.set(generator, [...history, generated.value]); return generated; }; const generateObservations = (gen) => generateObservation(gen); const generatedValues = generators.map(generateObservations); const initialObservation = { timestamp, duration, ...component, }; const generatedObservation = generatedValues.reduce((observation, generated) => Object.assign(observation, generated), initialObservation); return generatedObservation; }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/if-run/builtins/mock-observations/index.ts"],"names":[],"mappings":"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","sourcesContent":["import {DateTime, Duration} from 'luxon';\nimport {z} from 'zod';\n\nimport {PluginFactory} from '@grnsft/if-core/interfaces';\nimport {\n  PluginParams,\n  ConfigParams,\n  ObservationParams,\n} from '@grnsft/if-core/types';\nimport {ERRORS} from '@grnsft/if-core/utils';\n\nimport {validate} from '../../../common/util/validations';\n\nimport {STRINGS} from '../../config';\n\nimport {CommonGenerator} from './helpers/common-generator';\nimport {RandIntGenerator} from './helpers/rand-int-generator';\n\nimport {Generator} from './interfaces/index';\n\nconst {ConfigError} = ERRORS;\nconst {MISSING_CONFIG} = STRINGS;\n\nexport const MockObservations = PluginFactory({\n  configValidation: (config: ConfigParams) => {\n    if (!config || !Object.keys(config)?.length) {\n      throw new ConfigError(MISSING_CONFIG);\n    }\n\n    const schema = z.object({\n      'timestamp-from': z.string(),\n      'timestamp-to': z.string(),\n      duration: z.number().gt(0),\n      components: z.array(z.record(z.string())),\n      generators: z.object({\n        common: z.record(z.string().or(z.number())),\n        randint: z.record(z.object({min: z.number(), max: z.number()})),\n      }),\n    });\n\n    return validate<z.infer<typeof schema>>(schema, config);\n  },\n  implementation: async (inputs: PluginParams[], config: ConfigParams) => {\n    const {duration, timeBuckets, components, generators} =\n      generateParamsFromConfig(config);\n    const generatorToHistory = new Map<Generator, number[]>();\n\n    generators.forEach(generator => {\n      generatorToHistory.set(generator, []);\n    });\n\n    const defaults = inputs && inputs[0];\n\n    return Object.entries(components).reduce((acc: PluginParams[], item) => {\n      const component: any = item[1];\n      timeBuckets.forEach(timeBucket => {\n        const observation = createObservation(\n          {duration, component, timeBucket, generators},\n          generatorToHistory\n        );\n\n        acc.push(Object.assign({}, defaults, observation));\n      });\n\n      return acc;\n    }, []);\n  },\n});\n\n/**\n * Configures the MockObservations Plugin for IF\n */\nconst generateParamsFromConfig = (config: ConfigParams) => {\n  const {\n    'timestamp-from': timestampFrom,\n    'timestamp-to': timestampTo,\n    duration,\n    generators,\n    components,\n  } = config;\n\n  const convertedTimestampFrom = DateTime.fromISO(timestampFrom, {\n    zone: 'UTC',\n  });\n  const convertedTimestampTo = DateTime.fromISO(timestampTo, {zone: 'UTC'});\n\n  return {\n    duration,\n    timeBuckets: createTimeBuckets(\n      convertedTimestampFrom,\n      convertedTimestampTo,\n      duration\n    ),\n    generators: createGenerators(generators),\n    components,\n  };\n};\n\n/*\n * Creates time buckets based on start time, end time and duration of each bucket.\n */\nconst createTimeBuckets = (\n  timestampFrom: DateTime,\n  timestampTo: DateTime,\n  duration: number,\n  timeBuckets: DateTime[] = []\n): DateTime[] => {\n  if (\n    timestampFrom < timestampTo ||\n    timestampFrom.plus(Duration.fromObject({seconds: duration})) < timestampTo\n  ) {\n    return createTimeBuckets(\n      timestampFrom.plus(Duration.fromObject({seconds: duration})),\n      timestampTo,\n      duration,\n      [...timeBuckets, timestampFrom]\n    );\n  }\n  return timeBuckets;\n};\n\n/*\n * Creates generators based on a given config\n */\nconst createGenerators = (generatorsConfig: object): Generator[] => {\n  const createCommonGenerator = (config: any): Generator[] => [\n    CommonGenerator(config),\n  ];\n\n  const createRandIntGenerators = (config: any): Generator[] =>\n    Object.entries(config).map(([fieldToPopulate, value]) =>\n      RandIntGenerator(fieldToPopulate, value as Record<string, any>)\n    );\n\n  return Object.entries(generatorsConfig).flatMap(([key, value]) =>\n    key === 'randint'\n      ? createRandIntGenerators(value).flat()\n      : createCommonGenerator(value)\n  );\n};\n\n/*\n * Creates time buckets based on start time, end time and duration of each bucket.\n */\nconst createObservation = (\n  observationParams: ObservationParams,\n  generatorToHistory: Map<Generator, number[]>\n): PluginParams => {\n  const {duration, component, timeBucket, generators} = observationParams;\n  const timestamp = timeBucket.toISO();\n\n  const generateObservation = (generator: Generator) => {\n    const history = generatorToHistory.get(generator) || [];\n    const generated: Record<string, any> = generator.next(history);\n\n    generatorToHistory.set(generator, [...history, generated.value]);\n\n    return generated;\n  };\n\n  const generateObservations = (gen: Generator) => generateObservation(gen);\n  const generatedValues = generators.map(generateObservations);\n  const initialObservation: PluginParams = {\n    timestamp,\n    duration,\n    ...component,\n  };\n  const generatedObservation = generatedValues.reduce(\n    (observation, generated) => Object.assign(observation, generated),\n    initialObservation\n  );\n\n  return generatedObservation as PluginParams;\n};\n"]}