@eventual/core-runtime
Advanced tools
Comparing version 0.37.3 to 0.38.0
@@ -1,2 +0,2 @@ | ||
import { Entity, Attributes, EntityConsistencyOptions, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityWithMetadata } from "@eventual/core"; | ||
import { Attributes, Entity, EntityConsistencyOptions, EntityIndex, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityWithMetadata, KeyValue } from "@eventual/core"; | ||
import { EntityProvider } from "../../providers/entity-provider.js"; | ||
@@ -9,2 +9,6 @@ import { EntityStore, NormalizedEntityCompositeKey, NormalizedEntityCompositeKeyComplete, NormalizedEntityKeyCompletePart, NormalizedEntityTransactItem } from "../../stores/entity-store.js"; | ||
} | ||
export interface LocalEntity { | ||
data: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>; | ||
indices: Record<string, Map<KeyValue, Map<KeyValue, EntityWithMetadata>>>; | ||
} | ||
export declare class LocalEntityStore extends EntityStore { | ||
@@ -19,6 +23,7 @@ private props; | ||
protected _delete(entity: Entity, key: NormalizedEntityCompositeKeyComplete, options?: EntityConsistencyOptions | undefined): Promise<void>; | ||
protected _query(entity: Entity, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options?: EntityQueryOptions): Promise<EntityQueryResult>; | ||
protected _query(entity: Entity | EntityIndex, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options?: EntityQueryOptions): Promise<EntityQueryResult>; | ||
protected _transactWrite(items: NormalizedEntityTransactItem[]): Promise<void>; | ||
private getLocalEntity; | ||
private getPartitionMap; | ||
} | ||
//# sourceMappingURL=entity-store.d.ts.map |
@@ -25,6 +25,7 @@ "use strict"; | ||
const newVersion = options?.incrementVersion === false ? version : version + 1; | ||
this.getPartitionMap(entity, key.partition).set(key.sort?.keyValue ?? "default", { | ||
const newValue = { | ||
value, | ||
version: newVersion, | ||
}); | ||
}; | ||
setLocalEntity(this.getLocalEntity(entity), newValue, key, entity); | ||
this.props.localConnector.pushWorkflowTask({ | ||
@@ -49,13 +50,11 @@ entityName: entity.name, | ||
} | ||
if (!(0, entity_store_js_1.isCompleteKey)(key)) { | ||
throw new Error("Entity key cannot be partial for delete"); | ||
if (deleteLocalEntity(this.getLocalEntity(entity), key, entity)) { | ||
this.props.localConnector.pushWorkflowTask({ | ||
entityName: entity.name, | ||
key: (0, entity_store_js_1.convertNormalizedEntityKeyToMap)(key), | ||
operation: "remove", | ||
oldValue: item.value, | ||
oldVersion: item.version, | ||
}); | ||
} | ||
this.getPartitionMap(entity, key.partition).delete(key.sort?.keyValue ?? "default"); | ||
this.props.localConnector.pushWorkflowTask({ | ||
entityName: entity.name, | ||
key: (0, entity_store_js_1.convertNormalizedEntityKeyToMap)(key), | ||
operation: "remove", | ||
oldValue: item.value, | ||
oldVersion: item.version, | ||
}); | ||
} | ||
@@ -127,8 +126,21 @@ } | ||
} | ||
getPartitionMap(entity, partitionKey) { | ||
const _entity = (this.entities[entity.name] ??= new Map()); | ||
let partitionMap = _entity.get(partitionKey.keyValue); | ||
getLocalEntity(entityOrIndex) { | ||
const entity = entityOrIndex.kind === "Entity" | ||
? entityOrIndex | ||
: this.getEntity(entityOrIndex.entityName); | ||
const _entity = (this.entities[entity.name] ??= | ||
initializeLocalEntity(entity)); | ||
return _entity; | ||
} | ||
getPartitionMap(entityOrIndex, partitionKey) { | ||
const index = entityOrIndex.kind === "EntityIndex" ? entityOrIndex : undefined; | ||
const _entity = this.getLocalEntity(entityOrIndex); | ||
const table = index ? _entity.indices[index.name] : _entity.data; | ||
if (!table) { | ||
throw new Error(`Index ${index?.name} not found`); | ||
} | ||
let partitionMap = table.get(partitionKey.keyValue); | ||
if (!partitionMap) { | ||
partitionMap = new Map(); | ||
_entity.set(partitionKey.keyValue, partitionMap); | ||
table.set(partitionKey.keyValue, partitionMap); | ||
} | ||
@@ -139,2 +151,61 @@ return partitionMap; | ||
exports.LocalEntityStore = LocalEntityStore; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../../src/local/stores/entity-store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Entity,\n  Attributes,\n  EntityConsistencyOptions,\n  KeyValue,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityWithMetadata,\n  TransactionCancelled,\n  UnexpectedVersion,\n} from \"@eventual/core\";\nimport { assertNever } from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../../providers/entity-provider.js\";\nimport {\n  EntityStore,\n  NormalizedEntityCompositeKey,\n  NormalizedEntityCompositeKeyComplete,\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityTransactItem,\n  convertNormalizedEntityKeyToMap,\n  isCompleteKey,\n} from \"../../stores/entity-store.js\";\nimport { deserializeCompositeKey, serializeCompositeKey } from \"../../utils.js\";\nimport { LocalEnvConnector } from \"../local-container.js\";\nimport { paginateItems } from \"./pagination.js\";\n\nexport interface LocalEntityStoreProps {\n  localConnector: LocalEnvConnector;\n  entityProvider: EntityProvider;\n}\n\nexport class LocalEntityStore extends EntityStore {\n  private entities: Record<\n    string,\n    Map<KeyValue, Map<KeyValue, EntityWithMetadata>>\n  > = {};\n\n  constructor(private props: LocalEntityStoreProps) {\n    super(props.entityProvider);\n  }\n\n  protected override async _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined> {\n    return this.getPartitionMap(entity, key.partition).get(\n      key.sort?.keyValue ?? \"default\"\n    );\n  }\n\n  protected override async _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const { version = 0, value: oldValue } =\n      (await this._getWithMetadata(entity, key)) ?? {};\n    if (\n      options?.expectedVersion !== undefined &&\n      options.expectedVersion !== version\n    ) {\n      throw new Error(\n        `Expected entity to be of version ${options.expectedVersion} but found ${version}`\n      );\n    }\n    const newVersion =\n      options?.incrementVersion === false ? version : version + 1;\n\n    this.getPartitionMap(entity, key.partition).set(\n      key.sort?.keyValue ?? \"default\",\n      {\n        value,\n        version: newVersion,\n      }\n    );\n    this.props.localConnector.pushWorkflowTask({\n      entityName: entity.name,\n      key: convertNormalizedEntityKeyToMap(key),\n      operation: version === 0 ? (\"insert\" as const) : (\"modify\" as const),\n      newValue: value,\n      newVersion,\n      oldValue,\n      oldVersion: version,\n    });\n    return { version: newVersion };\n  }\n\n  protected override async _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const item = await this._getWithMetadata(entity, key);\n    if (item) {\n      if (options?.expectedVersion !== undefined) {\n        if (options.expectedVersion !== item.version) {\n          throw new UnexpectedVersion(\"Unexpected Version\");\n        }\n      }\n\n      if (!isCompleteKey(key)) {\n        throw new Error(\"Entity key cannot be partial for delete\");\n      }\n\n      this.getPartitionMap(entity, key.partition).delete(\n        key.sort?.keyValue ?? \"default\"\n      );\n      this.props.localConnector.pushWorkflowTask({\n        entityName: entity.name,\n        key: convertNormalizedEntityKeyToMap(key),\n        operation: \"remove\" as const,\n        oldValue: item.value,\n        oldVersion: item.version,\n      });\n    }\n  }\n\n  protected override async _query(\n    entity: Entity,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options?: EntityQueryOptions\n  ): Promise<EntityQueryResult> {\n    const partition = this.getPartitionMap(entity, queryKey.partition);\n    const entries = partition ? [...partition.entries()] : [];\n\n    const { items, nextToken } = paginateItems(\n      entries,\n      (a, b) =>\n        typeof a[0] === \"string\"\n          ? a[0].localeCompare(b[0] as string)\n          : typeof a[0] === \"number\"\n          ? a[0] - (b[0] as number)\n          : 0,\n      undefined,\n      undefined,\n      options?.limit,\n      options?.nextToken\n    );\n\n    // values should be sorted\n    return {\n      entries: items?.map(\n        ([, value]) =>\n          ({\n            value: value.value,\n            version: value.version,\n          } satisfies EntityWithMetadata)\n      ),\n      nextToken,\n    };\n  }\n\n  protected override async _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void> {\n    const keysAndVersions = Object.fromEntries(\n      items.map((item) => {\n        return [\n          serializeCompositeKey(item.entity.name, item.key),\n          item.operation === \"condition\"\n            ? item.version\n            : item.options?.expectedVersion,\n        ] as const;\n      })\n    );\n    /**\n     * Evaluate the expected versions against the current state and return the results.\n     *\n     * This is similar to calling TransactWriteItem in dynamo with only ConditionChecks and then\n     * handling the errors.\n     */\n    const consistencyResults = await Promise.all(\n      Object.entries(keysAndVersions).map(async ([sKey, expectedVersion]) => {\n        if (expectedVersion === undefined) {\n          return true;\n        }\n        const [entityName, key] = deserializeCompositeKey(sKey);\n        const { version } = (await this.getWithMetadata(entityName, key)) ?? {\n          version: 0,\n        };\n        return version === expectedVersion;\n      })\n    );\n    if (consistencyResults.some((r) => !r)) {\n      throw new TransactionCancelled(\n        consistencyResults.map((r) =>\n          r ? undefined : new UnexpectedVersion(\"Unexpected Version\")\n        )\n      );\n    }\n    /**\n     * After ensuring that all of the expected versions are accurate, actually perform the writes.\n     * Here we assume that the write operations are synchronous and that\n     * the state of the condition checks will not be invalided.\n     */\n    await Promise.all(\n      items.map(async (item) => {\n        if (item.operation === \"set\") {\n          return await this._set(\n            item.entity,\n            item.value,\n            item.key,\n            item.options\n          );\n        } else if (item.operation === \"delete\") {\n          return await this._delete(item.entity, item.key, item.options);\n        } else if (item.operation === \"condition\") {\n          // no op\n          return;\n        }\n        return assertNever(item);\n      })\n    );\n  }\n\n  private getPartitionMap(\n    entity: Entity,\n    partitionKey: NormalizedEntityKeyCompletePart\n  ) {\n    const _entity = (this.entities[entity.name] ??= new Map<\n      KeyValue,\n      Map<KeyValue, EntityWithMetadata>\n    >());\n    let partitionMap = _entity.get(partitionKey.keyValue);\n    if (!partitionMap) {\n      partitionMap = new Map<KeyValue, EntityWithMetadata>();\n      _entity.set(partitionKey.keyValue, partitionMap);\n    }\n    return partitionMap;\n  }\n}\n"]} | ||
function initializeLocalEntity(entity) { | ||
return { | ||
data: new Map(), | ||
indices: Object.fromEntries(entity.indices.map((i) => [ | ||
i.name, | ||
new Map(), | ||
])), | ||
}; | ||
} | ||
function setLocalEntity(localEntity, value, key, entity) { | ||
updatePartitionEntry(localEntity.data, key, value); | ||
entity.indices.forEach((i) => { | ||
const localIndex = localEntity.indices[i.name]; | ||
if (!localIndex) { | ||
return; | ||
} | ||
const normalizedKey = (0, entity_store_js_1.normalizeCompositeKey)(i.key, value.value); | ||
// if the key isn't complete (missing parts of the index composite key), ignore this item | ||
if ((0, entity_store_js_1.isCompleteKey)(normalizedKey)) { | ||
updatePartitionEntry(localIndex, normalizedKey, value); | ||
} | ||
}); | ||
function updatePartitionEntry(store, key, value) { | ||
let partitionMap = store.get(key.partition.keyValue); | ||
if (!partitionMap) { | ||
partitionMap = new Map(); | ||
store.set(key.partition.keyValue, partitionMap); | ||
} | ||
partitionMap.set(key.sort?.keyValue ?? "default", value); | ||
} | ||
} | ||
function deleteLocalEntity(localEntity, key, entity) { | ||
const value = localEntity.data | ||
.get(key.partition.keyValue) | ||
?.get(key.sort?.keyValue ?? "default"); | ||
if (!value) { | ||
return false; | ||
} | ||
const deleted = deletePartitionEntry(localEntity.data, key); | ||
entity.indices.forEach((i) => { | ||
const localIndex = localEntity.indices[i.name]; | ||
if (!localIndex) { | ||
return; | ||
} | ||
const normalizedKey = (0, entity_store_js_1.normalizeCompositeKey)(i.key, value.value); | ||
// if the key isn't complete (missing parts of the index composite key), ignore this item | ||
if ((0, entity_store_js_1.isCompleteKey)(normalizedKey)) { | ||
deletePartitionEntry(localIndex, normalizedKey); | ||
} | ||
}); | ||
return deleted; | ||
function deletePartitionEntry(store, key) { | ||
const partitionMap = store.get(key.partition.keyValue); | ||
if (partitionMap) { | ||
return partitionMap.delete(key.sort?.keyValue ?? "default"); | ||
} | ||
return false; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../../src/local/stores/entity-store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Attributes,\n  Entity,\n  EntityConsistencyOptions,\n  EntityIndex,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityWithMetadata,\n  KeyValue,\n  TransactionCancelled,\n  UnexpectedVersion,\n} from \"@eventual/core\";\nimport { assertNever } from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../../providers/entity-provider.js\";\nimport {\n  EntityStore,\n  NormalizedEntityCompositeKey,\n  NormalizedEntityCompositeKeyComplete,\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityTransactItem,\n  convertNormalizedEntityKeyToMap,\n  isCompleteKey,\n  normalizeCompositeKey,\n} from \"../../stores/entity-store.js\";\nimport { deserializeCompositeKey, serializeCompositeKey } from \"../../utils.js\";\nimport { LocalEnvConnector } from \"../local-container.js\";\nimport { paginateItems } from \"./pagination.js\";\n\nexport interface LocalEntityStoreProps {\n  localConnector: LocalEnvConnector;\n  entityProvider: EntityProvider;\n}\n\nexport interface LocalEntity {\n  data: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>;\n  indices: Record<string, Map<KeyValue, Map<KeyValue, EntityWithMetadata>>>;\n}\n\nexport class LocalEntityStore extends EntityStore {\n  private entities: Record<string, LocalEntity> = {};\n\n  constructor(private props: LocalEntityStoreProps) {\n    super(props.entityProvider);\n  }\n\n  protected override async _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined> {\n    return this.getPartitionMap(entity, key.partition).get(\n      key.sort?.keyValue ?? \"default\"\n    );\n  }\n\n  protected override async _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const { version = 0, value: oldValue } =\n      (await this._getWithMetadata(entity, key)) ?? {};\n    if (\n      options?.expectedVersion !== undefined &&\n      options.expectedVersion !== version\n    ) {\n      throw new Error(\n        `Expected entity to be of version ${options.expectedVersion} but found ${version}`\n      );\n    }\n    const newVersion =\n      options?.incrementVersion === false ? version : version + 1;\n\n    const newValue = {\n      value,\n      version: newVersion,\n    };\n\n    setLocalEntity(this.getLocalEntity(entity), newValue, key, entity);\n\n    this.props.localConnector.pushWorkflowTask({\n      entityName: entity.name,\n      key: convertNormalizedEntityKeyToMap(key),\n      operation: version === 0 ? (\"insert\" as const) : (\"modify\" as const),\n      newValue: value,\n      newVersion,\n      oldValue,\n      oldVersion: version,\n    });\n    return { version: newVersion };\n  }\n\n  protected override async _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const item = await this._getWithMetadata(entity, key);\n    if (item) {\n      if (options?.expectedVersion !== undefined) {\n        if (options.expectedVersion !== item.version) {\n          throw new UnexpectedVersion(\"Unexpected Version\");\n        }\n      }\n\n      if (deleteLocalEntity(this.getLocalEntity(entity), key, entity)) {\n        this.props.localConnector.pushWorkflowTask({\n          entityName: entity.name,\n          key: convertNormalizedEntityKeyToMap(key),\n          operation: \"remove\" as const,\n          oldValue: item.value,\n          oldVersion: item.version,\n        });\n      }\n    }\n  }\n\n  protected override async _query(\n    entity: Entity | EntityIndex,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options?: EntityQueryOptions\n  ): Promise<EntityQueryResult> {\n    const partition = this.getPartitionMap(entity, queryKey.partition);\n    const entries = partition ? [...partition.entries()] : [];\n\n    const { items, nextToken } = paginateItems(\n      entries,\n      (a, b) =>\n        typeof a[0] === \"string\"\n          ? a[0].localeCompare(b[0] as string)\n          : typeof a[0] === \"number\"\n          ? a[0] - (b[0] as number)\n          : 0,\n      undefined,\n      undefined,\n      options?.limit,\n      options?.nextToken\n    );\n\n    // values should be sorted\n    return {\n      entries: items?.map(\n        ([, value]) =>\n          ({\n            value: value.value,\n            version: value.version,\n          } satisfies EntityWithMetadata)\n      ),\n      nextToken,\n    };\n  }\n\n  protected override async _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void> {\n    const keysAndVersions = Object.fromEntries(\n      items.map((item) => {\n        return [\n          serializeCompositeKey(item.entity.name, item.key),\n          item.operation === \"condition\"\n            ? item.version\n            : item.options?.expectedVersion,\n        ] as const;\n      })\n    );\n    /**\n     * Evaluate the expected versions against the current state and return the results.\n     *\n     * This is similar to calling TransactWriteItem in dynamo with only ConditionChecks and then\n     * handling the errors.\n     */\n    const consistencyResults = await Promise.all(\n      Object.entries(keysAndVersions).map(async ([sKey, expectedVersion]) => {\n        if (expectedVersion === undefined) {\n          return true;\n        }\n        const [entityName, key] = deserializeCompositeKey(sKey);\n        const { version } = (await this.getWithMetadata(entityName, key)) ?? {\n          version: 0,\n        };\n        return version === expectedVersion;\n      })\n    );\n    if (consistencyResults.some((r) => !r)) {\n      throw new TransactionCancelled(\n        consistencyResults.map((r) =>\n          r ? undefined : new UnexpectedVersion(\"Unexpected Version\")\n        )\n      );\n    }\n    /**\n     * After ensuring that all of the expected versions are accurate, actually perform the writes.\n     * Here we assume that the write operations are synchronous and that\n     * the state of the condition checks will not be invalided.\n     */\n    await Promise.all(\n      items.map(async (item) => {\n        if (item.operation === \"set\") {\n          return await this._set(\n            item.entity,\n            item.value,\n            item.key,\n            item.options\n          );\n        } else if (item.operation === \"delete\") {\n          return await this._delete(item.entity, item.key, item.options);\n        } else if (item.operation === \"condition\") {\n          // no op\n          return;\n        }\n        return assertNever(item);\n      })\n    );\n  }\n\n  private getLocalEntity(entityOrIndex: Entity | EntityIndex) {\n    const entity =\n      entityOrIndex.kind === \"Entity\"\n        ? entityOrIndex\n        : this.getEntity(entityOrIndex.entityName);\n    const _entity = (this.entities[entity.name] ??=\n      initializeLocalEntity(entity));\n    return _entity;\n  }\n\n  private getPartitionMap(\n    entityOrIndex: Entity | EntityIndex,\n    partitionKey: NormalizedEntityKeyCompletePart\n  ) {\n    const index =\n      entityOrIndex.kind === \"EntityIndex\" ? entityOrIndex : undefined;\n    const _entity = this.getLocalEntity(entityOrIndex);\n    const table = index ? _entity.indices[index.name] : _entity.data;\n    if (!table) {\n      throw new Error(`Index ${index?.name} not found`);\n    }\n    let partitionMap = table.get(partitionKey.keyValue);\n    if (!partitionMap) {\n      partitionMap = new Map<KeyValue, EntityWithMetadata>();\n      table.set(partitionKey.keyValue, partitionMap);\n    }\n    return partitionMap;\n  }\n}\n\nfunction initializeLocalEntity(entity: Entity): LocalEntity {\n  return {\n    data: new Map<KeyValue, Map<KeyValue, EntityWithMetadata>>(),\n    indices: Object.fromEntries(\n      entity.indices.map((i) => [\n        i.name,\n        new Map<KeyValue, Map<KeyValue, EntityWithMetadata>>(),\n      ])\n    ),\n  };\n}\n\nfunction setLocalEntity(\n  localEntity: LocalEntity,\n  value: EntityWithMetadata,\n  key: NormalizedEntityCompositeKeyComplete,\n  entity: Entity\n) {\n  updatePartitionEntry(localEntity.data, key, value);\n\n  entity.indices.forEach((i) => {\n    const localIndex = localEntity.indices[i.name];\n    if (!localIndex) {\n      return;\n    }\n    const normalizedKey = normalizeCompositeKey(i.key, value.value);\n\n    // if the key isn't complete (missing parts of the index composite key), ignore this item\n    if (isCompleteKey(normalizedKey)) {\n      updatePartitionEntry(localIndex, normalizedKey, value);\n    }\n  });\n\n  function updatePartitionEntry(\n    store: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>,\n    key: NormalizedEntityCompositeKeyComplete,\n    value: EntityWithMetadata\n  ) {\n    let partitionMap = store.get(key.partition.keyValue);\n    if (!partitionMap) {\n      partitionMap = new Map<KeyValue, EntityWithMetadata>();\n      store.set(key.partition.keyValue, partitionMap);\n    }\n    partitionMap.set(key.sort?.keyValue ?? \"default\", value);\n  }\n}\n\nfunction deleteLocalEntity(\n  localEntity: LocalEntity,\n  key: NormalizedEntityCompositeKeyComplete,\n  entity: Entity\n): boolean {\n  const value = localEntity.data\n    .get(key.partition.keyValue)\n    ?.get(key.sort?.keyValue ?? \"default\");\n\n  if (!value) {\n    return false;\n  }\n\n  const deleted = deletePartitionEntry(localEntity.data, key);\n\n  entity.indices.forEach((i) => {\n    const localIndex = localEntity.indices[i.name];\n    if (!localIndex) {\n      return;\n    }\n    const normalizedKey = normalizeCompositeKey(i.key, value.value);\n\n    // if the key isn't complete (missing parts of the index composite key), ignore this item\n    if (isCompleteKey(normalizedKey)) {\n      deletePartitionEntry(localIndex, normalizedKey);\n    }\n  });\n\n  return deleted;\n\n  function deletePartitionEntry(\n    store: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>,\n    key: NormalizedEntityCompositeKeyComplete\n  ) {\n    const partitionMap = store.get(key.partition.keyValue);\n    if (partitionMap) {\n      return partitionMap.delete(key.sort?.keyValue ?? \"default\");\n    }\n    return false;\n  }\n}\n"]} |
@@ -1,2 +0,2 @@ | ||
import type { Entity, Attributes, CompositeKey, EntityConsistencyOptions, KeyMap, KeyValue, QueryKey, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityTransactItem, EntityWithMetadata } from "@eventual/core"; | ||
import type { Entity, Attributes, CompositeKey, EntityConsistencyOptions, KeyMap, KeyValue, QueryKey, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityTransactItem, EntityWithMetadata, EntityIndex } from "@eventual/core"; | ||
import type { EntityHook, KeyDefinition, KeyDefinitionPart } from "@eventual/core/internal"; | ||
@@ -19,3 +19,4 @@ import { EntityProvider } from "../providers/entity-provider.js"; | ||
query(entityName: string, queryKey: QueryKey, options?: EntityQueryOptions | undefined): Promise<EntityQueryResult>; | ||
protected abstract _query(entity: Entity, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options: EntityQueryOptions | undefined): Promise<EntityQueryResult>; | ||
queryIndex(entityName: string, indexName: string, queryKey: QueryKey, options?: EntityQueryOptions | undefined): Promise<EntityQueryOptions>; | ||
protected abstract _query(entity: Entity | EntityIndex, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options: EntityQueryOptions | undefined): Promise<EntityQueryResult>; | ||
transactWrite(items: EntityTransactItem[]): Promise<void>; | ||
@@ -22,0 +23,0 @@ protected abstract _transactWrite(items: NormalizedEntityTransactItem[]): Promise<void>; |
@@ -43,2 +43,13 @@ "use strict"; | ||
} | ||
queryIndex(entityName, indexName, queryKey, options) { | ||
const index = this.getEntity(entityName).indices.find((i) => i.name === indexName); | ||
if (!index) { | ||
throw new Error(`Index ${indexName} was not found on entity ${entityName}`); | ||
} | ||
const normalizedKey = normalizeCompositeKey(index.key, queryKey); | ||
if (!isCompleteKeyPart(normalizedKey.partition)) { | ||
throw new Error("Entity Index partition key cannot be partial for query."); | ||
} | ||
return this._query(index, normalizedKey, options); | ||
} | ||
async transactWrite(items) { | ||
@@ -147,2 +158,2 @@ return this._transactWrite(items.map((item) => { | ||
exports.convertNormalizedEntityKeyToMap = convertNormalizedEntityKeyToMap; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../src/stores/entity-store.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  Entity,\n  Attributes,\n  CompositeKey,\n  EntityConsistencyOptions,\n  KeyMap,\n  KeyValue,\n  QueryKey,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityTransactItem,\n  EntityWithMetadata,\n} from \"@eventual/core\";\nimport type {\n  EntityHook,\n  KeyDefinition,\n  KeyDefinitionPart,\n} from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../providers/entity-provider.js\";\n\nexport abstract class EntityStore implements EntityHook {\n  constructor(private entityProvider: EntityProvider) {}\n\n  public async get(entityName: string, key: CompositeKey): Promise<any> {\n    return (await this.getWithMetadata(entityName, key))?.value;\n  }\n\n  public async getWithMetadata(\n    entityName: string,\n    key: CompositeKey\n  ): Promise<EntityWithMetadata | undefined> {\n    const entity = this.getEntity(entityName);\n    const normalizedCompositeKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedCompositeKey)) {\n      throw new Error(\"Key cannot be partial for get or getWithMetadata.\");\n    }\n\n    return this._getWithMetadata(entity, normalizedCompositeKey);\n  }\n\n  protected abstract _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined>;\n\n  public set(\n    entityName: string,\n    value: Attributes,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, value);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for set.\");\n    }\n\n    return this._set(entity, value, normalizedKey, options);\n  }\n\n  protected abstract _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }>;\n\n  public delete(\n    entityName: string,\n    key: CompositeKey,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for delete.\");\n    }\n\n    return this._delete(entity, normalizedKey, options);\n  }\n\n  protected abstract _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void>;\n\n  public query(\n    entityName: string,\n    queryKey: QueryKey,\n    options?: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, queryKey);\n\n    if (!isCompleteKeyPart(normalizedKey.partition)) {\n      throw new Error(\"Entity partition key cannot be partial for query\");\n    }\n\n    return this._query(\n      entity,\n      normalizedKey as NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n      options\n    );\n  }\n\n  protected abstract _query(\n    entity: Entity,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult>;\n\n  public async transactWrite(items: EntityTransactItem[]): Promise<void> {\n    return this._transactWrite(\n      items.map((item): NormalizedEntityTransactItem => {\n        const entity =\n          typeof item.entity === \"string\"\n            ? this.getEntity(item.entity)\n            : item.entity;\n        const keyValue = item.operation === \"set\" ? item.value : item.key;\n        const key = normalizeCompositeKey(entity, keyValue);\n        if (!isCompleteKey(key)) {\n          throw new Error(\n            \"Entity key cannot be partial for set, delete, or condition operations.\"\n          );\n        }\n\n        return item.operation === \"set\"\n          ? {\n              operation: \"set\",\n              entity,\n              key,\n              value: item.value,\n              options: item.options,\n            }\n          : item.operation === \"delete\"\n          ? {\n              operation: \"delete\",\n              entity,\n              key,\n              options: item.options,\n            }\n          : {\n              operation: \"condition\",\n              entity,\n              key,\n              version: item.version,\n            };\n      })\n    );\n  }\n\n  protected abstract _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void>;\n\n  protected getEntity(entityName: string) {\n    const entity = this.entityProvider.getEntity(entityName);\n\n    if (!entity) {\n      throw new Error(`Entity ${entityName} was not found.`);\n    }\n    return entity;\n  }\n}\n\nexport type NormalizedEntityTransactItem = {\n  entity: Entity;\n  key: NormalizedEntityCompositeKeyComplete;\n} & (\n  | {\n      operation: \"set\";\n      value: Attributes;\n      options?: EntitySetOptions;\n    }\n  | {\n      operation: \"delete\";\n      options?: EntityConsistencyOptions;\n    }\n  | {\n      operation: \"condition\";\n      version?: number;\n    }\n);\n\nexport interface NormalizedEntityKeyPartBase extends KeyDefinitionPart {\n  parts: { field: string; value: KeyValue }[];\n}\n\nexport type NormalizedEntityKeyPart =\n  | NormalizedEntityKeyPartialPart\n  | NormalizedEntityKeyCompletePart;\n\nexport interface NormalizedEntityKeyCompletePart\n  extends NormalizedEntityKeyPartBase {\n  keyValue: string | number;\n  partialValue: false;\n}\n\nexport interface NormalizedEntityKeyPartialPart\n  extends NormalizedEntityKeyPartBase {\n  keyValue?: string | number;\n  partialValue: true;\n}\n\nexport function isCompleteKeyPart(\n  key: NormalizedEntityKeyPart\n): key is NormalizedEntityKeyCompletePart {\n  return !key.partialValue;\n}\n\nexport function isCompleteKey(\n  key: NormalizedEntityCompositeKey\n): key is NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n> {\n  return (\n    isCompleteKeyPart(key.partition) &&\n    (!key.sort || isCompleteKeyPart(key.sort))\n  );\n}\n\nexport interface NormalizedEntityCompositeKey<\n  Partition extends NormalizedEntityKeyPart = NormalizedEntityKeyPart,\n  Sort extends NormalizedEntityKeyPart = NormalizedEntityKeyPart\n> {\n  partition: Partition;\n  sort?: Sort;\n}\n\nexport type NormalizedEntityCompositeKeyComplete = NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n>;\n\n/**\n * Generate properties for an entity key given the key definition and key values.\n */\nexport function normalizeCompositeKey<E extends Entity>(\n  entity: E | KeyDefinition,\n  key: Partial<CompositeKey>\n): NormalizedEntityCompositeKey {\n  const keyDef = \"partition\" in entity ? entity : entity.key;\n\n  const partitionCompositeKey = formatNormalizedPart(keyDef.partition, (p, i) =>\n    Array.isArray(key) ? key[i] : (key as KeyMap)[p]\n  );\n\n  const sortCompositeKey = keyDef.sort\n    ? formatNormalizedPart(keyDef.sort, (p, i) =>\n        Array.isArray(key)\n          ? key[keyDef.partition.attributes.length + i]\n          : (key as KeyMap)[p]\n      )\n    : undefined;\n\n  return sortCompositeKey\n    ? {\n        partition: partitionCompositeKey,\n        sort: sortCompositeKey,\n      }\n    : {\n        partition: partitionCompositeKey,\n      };\n}\n\nfunction formatNormalizedPart(\n  keyPart: KeyDefinitionPart,\n  valueRetriever: (field: string, index: number) => string | number\n): NormalizedEntityKeyPart {\n  const parts = keyPart.attributes.map((p, i) => ({\n    field: p,\n    value: valueRetriever(p, i),\n  }));\n\n  const missingValueIndex = parts.findIndex((p) => p.value === undefined);\n\n  return {\n    type: keyPart.type,\n    attributes: keyPart.attributes,\n    parts,\n    keyAttribute: keyPart.keyAttribute,\n    keyValue: (keyPart.type === \"number\"\n      ? parts[0]?.value\n      : (missingValueIndex === -1 ? parts : parts.slice(0, missingValueIndex))\n          .map((p) => p.value)\n          .join(\"#\")) as any,\n    partialValue: missingValueIndex !== -1,\n  };\n}\n\nexport function convertNormalizedEntityKeyToMap(\n  key: NormalizedEntityCompositeKey\n): KeyMap<any, any, any> {\n  console.log(\"input key\", JSON.stringify(key));\n  const generatedKey = Object.fromEntries([\n    ...key.partition.parts.map(({ field, value }) => [field, value]),\n    ...(key.sort\n      ? key.sort.parts.map(({ field, value }) => [field, value])\n      : []),\n  ]);\n  console.log(\"generated key\", JSON.stringify(generatedKey));\n  return generatedKey;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../src/stores/entity-store.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  Entity,\n  Attributes,\n  CompositeKey,\n  EntityConsistencyOptions,\n  KeyMap,\n  KeyValue,\n  QueryKey,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityTransactItem,\n  EntityWithMetadata,\n  EntityIndex,\n} from \"@eventual/core\";\nimport type {\n  EntityHook,\n  KeyDefinition,\n  KeyDefinitionPart,\n} from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../providers/entity-provider.js\";\n\nexport abstract class EntityStore implements EntityHook {\n  constructor(private entityProvider: EntityProvider) {}\n\n  public async get(entityName: string, key: CompositeKey): Promise<any> {\n    return (await this.getWithMetadata(entityName, key))?.value;\n  }\n\n  public async getWithMetadata(\n    entityName: string,\n    key: CompositeKey\n  ): Promise<EntityWithMetadata | undefined> {\n    const entity = this.getEntity(entityName);\n    const normalizedCompositeKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedCompositeKey)) {\n      throw new Error(\"Key cannot be partial for get or getWithMetadata.\");\n    }\n\n    return this._getWithMetadata(entity, normalizedCompositeKey);\n  }\n\n  protected abstract _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined>;\n\n  public set(\n    entityName: string,\n    value: Attributes,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, value);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for set.\");\n    }\n\n    return this._set(entity, value, normalizedKey, options);\n  }\n\n  protected abstract _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }>;\n\n  public delete(\n    entityName: string,\n    key: CompositeKey,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for delete.\");\n    }\n\n    return this._delete(entity, normalizedKey, options);\n  }\n\n  protected abstract _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void>;\n\n  public query(\n    entityName: string,\n    queryKey: QueryKey,\n    options?: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, queryKey);\n\n    if (!isCompleteKeyPart(normalizedKey.partition)) {\n      throw new Error(\"Entity partition key cannot be partial for query\");\n    }\n\n    return this._query(\n      entity,\n      normalizedKey as NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n      options\n    );\n  }\n\n  public queryIndex(\n    entityName: string,\n    indexName: string,\n    queryKey: QueryKey,\n    options?: EntityQueryOptions | undefined\n  ): Promise<EntityQueryOptions> {\n    const index = this.getEntity(entityName).indices.find(\n      (i) => i.name === indexName\n    );\n\n    if (!index) {\n      throw new Error(\n        `Index ${indexName} was not found on entity ${entityName}`\n      );\n    }\n\n    const normalizedKey = normalizeCompositeKey(index.key, queryKey);\n\n    if (!isCompleteKeyPart(normalizedKey.partition)) {\n      throw new Error(\n        \"Entity Index partition key cannot be partial for query.\"\n      );\n    }\n\n    return this._query(\n      index,\n      normalizedKey as NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n      options\n    );\n  }\n\n  protected abstract _query(\n    entity: Entity | EntityIndex,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult>;\n\n  public async transactWrite(items: EntityTransactItem[]): Promise<void> {\n    return this._transactWrite(\n      items.map((item): NormalizedEntityTransactItem => {\n        const entity =\n          typeof item.entity === \"string\"\n            ? this.getEntity(item.entity)\n            : item.entity;\n        const keyValue = item.operation === \"set\" ? item.value : item.key;\n        const key = normalizeCompositeKey(entity, keyValue);\n        if (!isCompleteKey(key)) {\n          throw new Error(\n            \"Entity key cannot be partial for set, delete, or condition operations.\"\n          );\n        }\n\n        return item.operation === \"set\"\n          ? {\n              operation: \"set\",\n              entity,\n              key,\n              value: item.value,\n              options: item.options,\n            }\n          : item.operation === \"delete\"\n          ? {\n              operation: \"delete\",\n              entity,\n              key,\n              options: item.options,\n            }\n          : {\n              operation: \"condition\",\n              entity,\n              key,\n              version: item.version,\n            };\n      })\n    );\n  }\n\n  protected abstract _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void>;\n\n  protected getEntity(entityName: string) {\n    const entity = this.entityProvider.getEntity(entityName);\n\n    if (!entity) {\n      throw new Error(`Entity ${entityName} was not found.`);\n    }\n    return entity;\n  }\n}\n\nexport type NormalizedEntityTransactItem = {\n  entity: Entity;\n  key: NormalizedEntityCompositeKeyComplete;\n} & (\n  | {\n      operation: \"set\";\n      value: Attributes;\n      options?: EntitySetOptions;\n    }\n  | {\n      operation: \"delete\";\n      options?: EntityConsistencyOptions;\n    }\n  | {\n      operation: \"condition\";\n      version?: number;\n    }\n);\n\nexport interface NormalizedEntityKeyPartBase extends KeyDefinitionPart {\n  parts: { field: string; value: KeyValue }[];\n}\n\nexport type NormalizedEntityKeyPart =\n  | NormalizedEntityKeyPartialPart\n  | NormalizedEntityKeyCompletePart;\n\nexport interface NormalizedEntityKeyCompletePart\n  extends NormalizedEntityKeyPartBase {\n  keyValue: string | number;\n  partialValue: false;\n}\n\nexport interface NormalizedEntityKeyPartialPart\n  extends NormalizedEntityKeyPartBase {\n  keyValue?: string | number;\n  partialValue: true;\n}\n\nexport function isCompleteKeyPart(\n  key: NormalizedEntityKeyPart\n): key is NormalizedEntityKeyCompletePart {\n  return !key.partialValue;\n}\n\nexport function isCompleteKey(\n  key: NormalizedEntityCompositeKey\n): key is NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n> {\n  return (\n    isCompleteKeyPart(key.partition) &&\n    (!key.sort || isCompleteKeyPart(key.sort))\n  );\n}\n\nexport interface NormalizedEntityCompositeKey<\n  Partition extends NormalizedEntityKeyPart = NormalizedEntityKeyPart,\n  Sort extends NormalizedEntityKeyPart = NormalizedEntityKeyPart\n> {\n  partition: Partition;\n  sort?: Sort;\n}\n\nexport type NormalizedEntityCompositeKeyComplete = NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n>;\n\n/**\n * Generate properties for an entity key given the key definition and key values.\n */\nexport function normalizeCompositeKey<E extends Entity>(\n  entity: E | KeyDefinition,\n  key: Partial<CompositeKey>\n): NormalizedEntityCompositeKey {\n  const keyDef = \"partition\" in entity ? entity : entity.key;\n\n  const partitionCompositeKey = formatNormalizedPart(keyDef.partition, (p, i) =>\n    Array.isArray(key) ? key[i] : (key as KeyMap)[p]\n  );\n\n  const sortCompositeKey = keyDef.sort\n    ? formatNormalizedPart(keyDef.sort, (p, i) =>\n        Array.isArray(key)\n          ? key[keyDef.partition.attributes.length + i]\n          : (key as KeyMap)[p]\n      )\n    : undefined;\n\n  return sortCompositeKey\n    ? {\n        partition: partitionCompositeKey,\n        sort: sortCompositeKey,\n      }\n    : {\n        partition: partitionCompositeKey,\n      };\n}\n\nfunction formatNormalizedPart(\n  keyPart: KeyDefinitionPart,\n  valueRetriever: (field: string, index: number) => string | number\n): NormalizedEntityKeyPart {\n  const parts = keyPart.attributes.map((p, i) => ({\n    field: p,\n    value: valueRetriever(p, i),\n  }));\n\n  const missingValueIndex = parts.findIndex((p) => p.value === undefined);\n\n  return {\n    type: keyPart.type,\n    attributes: keyPart.attributes,\n    parts,\n    keyAttribute: keyPart.keyAttribute,\n    keyValue: (keyPart.type === \"number\"\n      ? parts[0]?.value\n      : (missingValueIndex === -1 ? parts : parts.slice(0, missingValueIndex))\n          .map((p) => p.value)\n          .join(\"#\")) as any,\n    partialValue: missingValueIndex !== -1,\n  };\n}\n\nexport function convertNormalizedEntityKeyToMap(\n  key: NormalizedEntityCompositeKey\n): KeyMap<any, any, any> {\n  console.log(\"input key\", JSON.stringify(key));\n  const generatedKey = Object.fromEntries([\n    ...key.partition.parts.map(({ field, value }) => [field, value]),\n    ...(key.sort\n      ? key.sort.parts.map(({ field, value }) => [field, value])\n      : []),\n  ]);\n  console.log(\"generated key\", JSON.stringify(generatedKey));\n  return generatedKey;\n}\n"]} |
@@ -162,2 +162,5 @@ "use strict"; | ||
} | ||
else if ((0, internal_1.isEntityOperationOfType)("queryIndex", operation)) { | ||
return self.props.entityStore.queryIndex(operation.entityName, operation.indexName, ...operation.params); | ||
} | ||
return self.props.entityStore[operation.operation](operation.entityName, | ||
@@ -303,2 +306,2 @@ // @ts-ignore | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-call-executor.js","sourceRoot":"","sources":["../../src/workflow-call-executor.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ExecutionID, Workflow } from \"@eventual/core\";\nimport {\n  assertNever,\n  AwaitTimerCall,\n  BucketCall,\n  BucketGetObjectSerializedResult,\n  BucketRequest,\n  BucketRequestFailed,\n  BucketRequestSucceeded,\n  ChildWorkflowCall,\n  ChildWorkflowScheduled,\n  EmitEventsCall,\n  EntityCall,\n  EntityOperation,\n  EntityRequest,\n  EntityRequestFailed,\n  EntityRequestSucceeded,\n  EventsEmitted,\n  HistoryStateEvent,\n  InvokeTransactionCall,\n  isAwaitTimerCall,\n  isBucketCall,\n  isBucketCallType,\n  isChildExecutionTarget,\n  isChildWorkflowCall,\n  isConditionCall,\n  isEmitEventsCall,\n  isEntityCall,\n  isEntityOperationOfType,\n  isExpectSignalCall,\n  isInvokeTransactionCall,\n  isRegisterSignalHandlerCall,\n  isSendSignalCall,\n  isTaskCall,\n  SendSignalCall,\n  SignalSent,\n  TaskCall,\n  TaskScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  TransactionRequest,\n  TransactionRequestFailed,\n  TransactionRequestSucceeded,\n  WorkflowEventType,\n} from \"@eventual/core/internal\";\nimport stream from \"stream\";\nimport type { EventClient } from \"./clients/event-client.js\";\nimport type { ExecutionQueueClient } from \"./clients/execution-queue-client.js\";\nimport type { TaskClient, TaskWorkerRequest } from \"./clients/task-client.js\";\nimport type { TimerClient } from \"./clients/timer-client.js\";\nimport type { TransactionClient } from \"./clients/transaction-client.js\";\nimport type { WorkflowClient } from \"./clients/workflow-client.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution.js\";\nimport { normalizeError } from \"./result.js\";\nimport { computeScheduleDate } from \"./schedule.js\";\nimport type { BucketStore } from \"./stores/bucket-store.js\";\nimport type { EntityStore } from \"./stores/entity-store.js\";\nimport { createEvent } from \"./workflow-events.js\";\nimport type { WorkflowCall } from \"./workflow-executor.js\";\n\ninterface WorkflowCallExecutorProps {\n  bucketStore: BucketStore;\n  entityStore: EntityStore;\n  eventClient: EventClient;\n  executionQueueClient: ExecutionQueueClient;\n  taskClient: TaskClient;\n  timerClient: TimerClient;\n  transactionClient: TransactionClient;\n  workflowClient: WorkflowClient;\n}\n\n/**\n * Uses the clients to execute all supported calls and return events.\n */\nexport class WorkflowCallExecutor {\n  constructor(private props: WorkflowCallExecutorProps) {}\n\n  public async executeCall(\n    workflow: Workflow,\n    executionId: ExecutionID,\n    call: WorkflowCall,\n    baseTime: Date\n  ): Promise<HistoryStateEvent | undefined> {\n    if (isTaskCall(call.call)) {\n      return await this.scheduleTask(\n        workflow,\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isChildWorkflowCall(call.call)) {\n      return this.scheduleChildWorkflow(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isAwaitTimerCall(call.call)) {\n      // all timers are computed using the start time of the WorkflowTaskStarted\n      return this.startTimer(executionId, call.call, call.seq, baseTime);\n    } else if (isSendSignalCall(call.call)) {\n      return this.sendSignal(executionId, call.call, call.seq, baseTime);\n    } else if (isEmitEventsCall(call.call)) {\n      return this.emitEvents(call.call, call.seq, baseTime);\n    } else if (\n      isConditionCall(call.call) ||\n      isExpectSignalCall(call.call) ||\n      isRegisterSignalHandlerCall(call.call)\n    ) {\n      // do nothing\n      return undefined;\n    } else if (isEntityCall(call.call)) {\n      return this.executeEntityRequest(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isInvokeTransactionCall(call.call)) {\n      return this.invokeTransaction(executionId, call.call, call.seq, baseTime);\n    } else if (isBucketCall(call.call)) {\n      return this.invokeBucketRequest(\n        call.call,\n        executionId,\n        call.seq,\n        baseTime\n      );\n    } else {\n      return assertNever(call.call, `unknown call type`);\n    }\n  }\n\n  private async scheduleTask(\n    workflow: Workflow,\n    executionId: string,\n    call: TaskCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const request: TaskWorkerRequest = {\n      scheduledTime: baseTime.toISOString(),\n      workflowName: workflow.name,\n      executionId,\n      input: call.input,\n      taskName: call.name,\n      seq,\n      heartbeat: call.heartbeat,\n      retry: 0,\n    };\n\n    await this.props.taskClient.startTask(request);\n\n    return createEvent<TaskScheduled>(\n      {\n        type: WorkflowEventType.TaskScheduled,\n        seq,\n        name: call.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: ExecutionID,\n    call: ChildWorkflowCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startExecution({\n      workflow: call.name,\n      input: call.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, seq),\n      seq,\n      ...call.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>(\n      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq,\n        name: call.name,\n        input: call.input,\n      },\n      baseTime\n    );\n  }\n\n  private async startTimer(\n    executionId: string,\n    call: AwaitTimerCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<TimerScheduled> {\n    // TODO validate\n    await this.props.timerClient.scheduleEvent<TimerCompleted>({\n      event: {\n        type: WorkflowEventType.TimerCompleted,\n        seq,\n      },\n      schedule: call.schedule,\n      executionId,\n    });\n\n    return createEvent<TimerScheduled>(\n      {\n        type: WorkflowEventType.TimerScheduled,\n        seq,\n        untilTime: computeScheduleDate(call.schedule, baseTime).toISOString(),\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    call: SendSignalCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const childExecutionId = isChildExecutionTarget(call.target)\n      ? formatExecutionId(\n          call.target.workflowName,\n          formatChildExecutionName(executionId, call.target.seq)\n        )\n      : call.target.executionId;\n\n    await this.props.executionQueueClient.sendSignal({\n      signal: call.signalId,\n      execution: childExecutionId,\n      id: `${executionId}/${seq}`,\n      payload: call.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq,\n        signalId: call.signalId,\n        payload: call.payload,\n      },\n      baseTime\n    );\n  }\n\n  private async emitEvents(call: EmitEventsCall, seq: number, baseTime: Date) {\n    await this.props.eventClient.emitEvents(...call.events);\n    return createEvent<EventsEmitted>(\n      {\n        type: WorkflowEventType.EventsEmitted,\n        events: call.events,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async executeEntityRequest(\n    executionId: string,\n    call: EntityCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const self = this;\n    try {\n      const result = await invokeEntityOperation(call);\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestSucceeded>(\n          {\n            type: WorkflowEventType.EntityRequestSucceeded,\n            operation: call.operation,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            result,\n            seq,\n          },\n          baseTime\n        )\n      );\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestFailed>(\n          {\n            type: WorkflowEventType.EntityRequestFailed,\n            seq,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            operation: call.operation,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<EntityRequest>(\n      {\n        type: WorkflowEventType.EntityRequest,\n        operation: call,\n        seq,\n      },\n      baseTime\n    );\n\n    async function invokeEntityOperation(operation: EntityOperation) {\n      if (isEntityOperationOfType(\"transact\", operation)) {\n        return self.props.entityStore.transactWrite(operation.items);\n      }\n      return self.props.entityStore[operation.operation](\n        operation.entityName,\n        // @ts-ignore\n        ...operation.params\n      );\n    }\n  }\n\n  private async invokeTransaction(\n    executionId: string,\n    call: InvokeTransactionCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    try {\n      const result = await this.props.transactionClient.executeTransaction({\n        input: call.input,\n        transaction: call.transactionName,\n      });\n      if (result.succeeded) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestSucceeded>(\n            {\n              type: WorkflowEventType.TransactionRequestSucceeded,\n              result: result.output,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestFailed>(\n            {\n              type: WorkflowEventType.TransactionRequestFailed,\n              error: \"Transaction Failed\",\n              message: \"\",\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<TransactionRequestFailed>(\n          {\n            type: WorkflowEventType.TransactionRequestFailed,\n            ...normalizeError(err),\n            seq,\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<TransactionRequest>(\n      {\n        type: WorkflowEventType.TransactionRequest,\n        input: call.input,\n        transactionName: call.transactionName,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async invokeBucketRequest(\n    call: BucketCall,\n    executionId: string,\n    seq: number,\n    baseTime: Date\n  ) {\n    if (isBucketCallType(\"put\", call)) {\n      // handle put separately to serialize the input\n      const [key, data] = call.params;\n\n      const buffer =\n        typeof data === \"string\" || data instanceof Buffer\n          ? data\n          : await streamToBuffer(data);\n\n      try {\n        const result = await this.props.bucketStore.put(\n          call.bucketName,\n          key,\n          buffer\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: \"put\",\n              result: {\n                etag: result.etag,\n              },\n              seq,\n            },\n            baseTime\n          )\n        );\n      } catch (err) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestFailed>(\n            {\n              type: WorkflowEventType.BucketRequestFailed,\n              operation: \"put\",\n              seq,\n              ...normalizeError(err),\n            },\n            baseTime\n          )\n        );\n      }\n\n      return createEvent<BucketRequest>(\n        {\n          type: WorkflowEventType.BucketRequest,\n          operation: {\n            operation: \"put\",\n            bucketName: call.bucketName,\n            key,\n            // serialize the data put into a string to be stored\n            data:\n              typeof buffer === \"string\" ? buffer : buffer.toString(\"base64\"),\n            isBase64Encoded: typeof buffer !== \"string\",\n          },\n          seq,\n        },\n        baseTime\n      );\n    }\n\n    try {\n      // handle get separately to serialize the result\n      if (isBucketCallType(\"get\", call)) {\n        const result = await this.props.bucketStore.get(\n          call.bucketName,\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result: result\n                ? ({\n                    // serialize the data retrieved data to be stored\n                    body: (\n                      await streamToBuffer(result.body)\n                    ).toString(\"base64\"),\n                    base64Encoded: true,\n                    contentLength: result.contentLength,\n                    etag: result.etag,\n                  } satisfies BucketGetObjectSerializedResult)\n                : undefined,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        const result = await this.props.bucketStore[call.operation](\n          call.bucketName,\n          // @ts-ignore\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result,\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<BucketRequestFailed>(\n          {\n            type: WorkflowEventType.BucketRequestFailed,\n            operation: call.operation,\n            seq,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<BucketRequest>(\n      {\n        type: WorkflowEventType.BucketRequest,\n        operation: {\n          operation: call.operation,\n          bucketName: call.bucketName,\n          // @ts-ignore\n          params: call.params,\n        },\n        seq,\n      },\n      baseTime\n    );\n  }\n}\n\nasync function streamToBuffer(stream: stream.Readable) {\n  // lets have a ReadableStream as a stream variable\n  const chunks = [];\n\n  for await (const chunk of stream) {\n    chunks.push(Buffer.from(chunk));\n  }\n\n  return Buffer.concat(chunks);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-call-executor.js","sourceRoot":"","sources":["../../src/workflow-call-executor.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ExecutionID, Workflow } from \"@eventual/core\";\nimport {\n  assertNever,\n  AwaitTimerCall,\n  BucketCall,\n  BucketGetObjectSerializedResult,\n  BucketRequest,\n  BucketRequestFailed,\n  BucketRequestSucceeded,\n  ChildWorkflowCall,\n  ChildWorkflowScheduled,\n  EmitEventsCall,\n  EntityCall,\n  EntityOperation,\n  EntityRequest,\n  EntityRequestFailed,\n  EntityRequestSucceeded,\n  EventsEmitted,\n  HistoryStateEvent,\n  InvokeTransactionCall,\n  isAwaitTimerCall,\n  isBucketCall,\n  isBucketCallType,\n  isChildExecutionTarget,\n  isChildWorkflowCall,\n  isConditionCall,\n  isEmitEventsCall,\n  isEntityCall,\n  isEntityOperationOfType,\n  isExpectSignalCall,\n  isInvokeTransactionCall,\n  isRegisterSignalHandlerCall,\n  isSendSignalCall,\n  isTaskCall,\n  SendSignalCall,\n  SignalSent,\n  TaskCall,\n  TaskScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  TransactionRequest,\n  TransactionRequestFailed,\n  TransactionRequestSucceeded,\n  WorkflowEventType,\n} from \"@eventual/core/internal\";\nimport stream from \"stream\";\nimport type { EventClient } from \"./clients/event-client.js\";\nimport type { ExecutionQueueClient } from \"./clients/execution-queue-client.js\";\nimport type { TaskClient, TaskWorkerRequest } from \"./clients/task-client.js\";\nimport type { TimerClient } from \"./clients/timer-client.js\";\nimport type { TransactionClient } from \"./clients/transaction-client.js\";\nimport type { WorkflowClient } from \"./clients/workflow-client.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution.js\";\nimport { normalizeError } from \"./result.js\";\nimport { computeScheduleDate } from \"./schedule.js\";\nimport type { BucketStore } from \"./stores/bucket-store.js\";\nimport type { EntityStore } from \"./stores/entity-store.js\";\nimport { createEvent } from \"./workflow-events.js\";\nimport type { WorkflowCall } from \"./workflow-executor.js\";\n\ninterface WorkflowCallExecutorProps {\n  bucketStore: BucketStore;\n  entityStore: EntityStore;\n  eventClient: EventClient;\n  executionQueueClient: ExecutionQueueClient;\n  taskClient: TaskClient;\n  timerClient: TimerClient;\n  transactionClient: TransactionClient;\n  workflowClient: WorkflowClient;\n}\n\n/**\n * Uses the clients to execute all supported calls and return events.\n */\nexport class WorkflowCallExecutor {\n  constructor(private props: WorkflowCallExecutorProps) {}\n\n  public async executeCall(\n    workflow: Workflow,\n    executionId: ExecutionID,\n    call: WorkflowCall,\n    baseTime: Date\n  ): Promise<HistoryStateEvent | undefined> {\n    if (isTaskCall(call.call)) {\n      return await this.scheduleTask(\n        workflow,\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isChildWorkflowCall(call.call)) {\n      return this.scheduleChildWorkflow(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isAwaitTimerCall(call.call)) {\n      // all timers are computed using the start time of the WorkflowTaskStarted\n      return this.startTimer(executionId, call.call, call.seq, baseTime);\n    } else if (isSendSignalCall(call.call)) {\n      return this.sendSignal(executionId, call.call, call.seq, baseTime);\n    } else if (isEmitEventsCall(call.call)) {\n      return this.emitEvents(call.call, call.seq, baseTime);\n    } else if (\n      isConditionCall(call.call) ||\n      isExpectSignalCall(call.call) ||\n      isRegisterSignalHandlerCall(call.call)\n    ) {\n      // do nothing\n      return undefined;\n    } else if (isEntityCall(call.call)) {\n      return this.executeEntityRequest(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isInvokeTransactionCall(call.call)) {\n      return this.invokeTransaction(executionId, call.call, call.seq, baseTime);\n    } else if (isBucketCall(call.call)) {\n      return this.invokeBucketRequest(\n        call.call,\n        executionId,\n        call.seq,\n        baseTime\n      );\n    } else {\n      return assertNever(call.call, `unknown call type`);\n    }\n  }\n\n  private async scheduleTask(\n    workflow: Workflow,\n    executionId: string,\n    call: TaskCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const request: TaskWorkerRequest = {\n      scheduledTime: baseTime.toISOString(),\n      workflowName: workflow.name,\n      executionId,\n      input: call.input,\n      taskName: call.name,\n      seq,\n      heartbeat: call.heartbeat,\n      retry: 0,\n    };\n\n    await this.props.taskClient.startTask(request);\n\n    return createEvent<TaskScheduled>(\n      {\n        type: WorkflowEventType.TaskScheduled,\n        seq,\n        name: call.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: ExecutionID,\n    call: ChildWorkflowCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startExecution({\n      workflow: call.name,\n      input: call.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, seq),\n      seq,\n      ...call.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>(\n      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq,\n        name: call.name,\n        input: call.input,\n      },\n      baseTime\n    );\n  }\n\n  private async startTimer(\n    executionId: string,\n    call: AwaitTimerCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<TimerScheduled> {\n    // TODO validate\n    await this.props.timerClient.scheduleEvent<TimerCompleted>({\n      event: {\n        type: WorkflowEventType.TimerCompleted,\n        seq,\n      },\n      schedule: call.schedule,\n      executionId,\n    });\n\n    return createEvent<TimerScheduled>(\n      {\n        type: WorkflowEventType.TimerScheduled,\n        seq,\n        untilTime: computeScheduleDate(call.schedule, baseTime).toISOString(),\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    call: SendSignalCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const childExecutionId = isChildExecutionTarget(call.target)\n      ? formatExecutionId(\n          call.target.workflowName,\n          formatChildExecutionName(executionId, call.target.seq)\n        )\n      : call.target.executionId;\n\n    await this.props.executionQueueClient.sendSignal({\n      signal: call.signalId,\n      execution: childExecutionId,\n      id: `${executionId}/${seq}`,\n      payload: call.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq,\n        signalId: call.signalId,\n        payload: call.payload,\n      },\n      baseTime\n    );\n  }\n\n  private async emitEvents(call: EmitEventsCall, seq: number, baseTime: Date) {\n    await this.props.eventClient.emitEvents(...call.events);\n    return createEvent<EventsEmitted>(\n      {\n        type: WorkflowEventType.EventsEmitted,\n        events: call.events,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async executeEntityRequest(\n    executionId: string,\n    call: EntityCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const self = this;\n    try {\n      const result = await invokeEntityOperation(call);\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestSucceeded>(\n          {\n            type: WorkflowEventType.EntityRequestSucceeded,\n            operation: call.operation,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            result,\n            seq,\n          },\n          baseTime\n        )\n      );\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestFailed>(\n          {\n            type: WorkflowEventType.EntityRequestFailed,\n            seq,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            operation: call.operation,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<EntityRequest>(\n      {\n        type: WorkflowEventType.EntityRequest,\n        operation: call,\n        seq,\n      },\n      baseTime\n    );\n\n    async function invokeEntityOperation(operation: EntityOperation) {\n      if (isEntityOperationOfType(\"transact\", operation)) {\n        return self.props.entityStore.transactWrite(operation.items);\n      } else if (isEntityOperationOfType(\"queryIndex\", operation)) {\n        return self.props.entityStore.queryIndex(\n          operation.entityName,\n          operation.indexName,\n          ...operation.params\n        );\n      }\n      return self.props.entityStore[operation.operation](\n        operation.entityName,\n        // @ts-ignore\n        ...operation.params\n      );\n    }\n  }\n\n  private async invokeTransaction(\n    executionId: string,\n    call: InvokeTransactionCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    try {\n      const result = await this.props.transactionClient.executeTransaction({\n        input: call.input,\n        transaction: call.transactionName,\n      });\n      if (result.succeeded) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestSucceeded>(\n            {\n              type: WorkflowEventType.TransactionRequestSucceeded,\n              result: result.output,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestFailed>(\n            {\n              type: WorkflowEventType.TransactionRequestFailed,\n              error: \"Transaction Failed\",\n              message: \"\",\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<TransactionRequestFailed>(\n          {\n            type: WorkflowEventType.TransactionRequestFailed,\n            ...normalizeError(err),\n            seq,\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<TransactionRequest>(\n      {\n        type: WorkflowEventType.TransactionRequest,\n        input: call.input,\n        transactionName: call.transactionName,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async invokeBucketRequest(\n    call: BucketCall,\n    executionId: string,\n    seq: number,\n    baseTime: Date\n  ) {\n    if (isBucketCallType(\"put\", call)) {\n      // handle put separately to serialize the input\n      const [key, data] = call.params;\n\n      const buffer =\n        typeof data === \"string\" || data instanceof Buffer\n          ? data\n          : await streamToBuffer(data);\n\n      try {\n        const result = await this.props.bucketStore.put(\n          call.bucketName,\n          key,\n          buffer\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: \"put\",\n              result: {\n                etag: result.etag,\n              },\n              seq,\n            },\n            baseTime\n          )\n        );\n      } catch (err) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestFailed>(\n            {\n              type: WorkflowEventType.BucketRequestFailed,\n              operation: \"put\",\n              seq,\n              ...normalizeError(err),\n            },\n            baseTime\n          )\n        );\n      }\n\n      return createEvent<BucketRequest>(\n        {\n          type: WorkflowEventType.BucketRequest,\n          operation: {\n            operation: \"put\",\n            bucketName: call.bucketName,\n            key,\n            // serialize the data put into a string to be stored\n            data:\n              typeof buffer === \"string\" ? buffer : buffer.toString(\"base64\"),\n            isBase64Encoded: typeof buffer !== \"string\",\n          },\n          seq,\n        },\n        baseTime\n      );\n    }\n\n    try {\n      // handle get separately to serialize the result\n      if (isBucketCallType(\"get\", call)) {\n        const result = await this.props.bucketStore.get(\n          call.bucketName,\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result: result\n                ? ({\n                    // serialize the data retrieved data to be stored\n                    body: (\n                      await streamToBuffer(result.body)\n                    ).toString(\"base64\"),\n                    base64Encoded: true,\n                    contentLength: result.contentLength,\n                    etag: result.etag,\n                  } satisfies BucketGetObjectSerializedResult)\n                : undefined,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        const result = await this.props.bucketStore[call.operation](\n          call.bucketName,\n          // @ts-ignore\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result,\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<BucketRequestFailed>(\n          {\n            type: WorkflowEventType.BucketRequestFailed,\n            operation: call.operation,\n            seq,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<BucketRequest>(\n      {\n        type: WorkflowEventType.BucketRequest,\n        operation: {\n          operation: call.operation,\n          bucketName: call.bucketName,\n          // @ts-ignore\n          params: call.params,\n        },\n        seq,\n      },\n      baseTime\n    );\n  }\n}\n\nasync function streamToBuffer(stream: stream.Readable) {\n  // lets have a ReadableStream as a stream variable\n  const chunks = [];\n\n  for await (const chunk of stream) {\n    chunks.push(Buffer.from(chunk));\n  }\n\n  return Buffer.concat(chunks);\n}\n"]} |
@@ -1,2 +0,2 @@ | ||
import { Entity, Attributes, EntityConsistencyOptions, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityWithMetadata } from "@eventual/core"; | ||
import { Attributes, Entity, EntityConsistencyOptions, EntityIndex, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityWithMetadata, KeyValue } from "@eventual/core"; | ||
import { EntityProvider } from "../../providers/entity-provider.js"; | ||
@@ -9,2 +9,6 @@ import { EntityStore, NormalizedEntityCompositeKey, NormalizedEntityCompositeKeyComplete, NormalizedEntityKeyCompletePart, NormalizedEntityTransactItem } from "../../stores/entity-store.js"; | ||
} | ||
export interface LocalEntity { | ||
data: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>; | ||
indices: Record<string, Map<KeyValue, Map<KeyValue, EntityWithMetadata>>>; | ||
} | ||
export declare class LocalEntityStore extends EntityStore { | ||
@@ -19,6 +23,7 @@ private props; | ||
protected _delete(entity: Entity, key: NormalizedEntityCompositeKeyComplete, options?: EntityConsistencyOptions | undefined): Promise<void>; | ||
protected _query(entity: Entity, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options?: EntityQueryOptions): Promise<EntityQueryResult>; | ||
protected _query(entity: Entity | EntityIndex, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options?: EntityQueryOptions): Promise<EntityQueryResult>; | ||
protected _transactWrite(items: NormalizedEntityTransactItem[]): Promise<void>; | ||
private getLocalEntity; | ||
private getPartitionMap; | ||
} | ||
//# sourceMappingURL=entity-store.d.ts.map |
import { TransactionCancelled, UnexpectedVersion, } from "@eventual/core"; | ||
import { assertNever } from "@eventual/core/internal"; | ||
import { EntityStore, convertNormalizedEntityKeyToMap, isCompleteKey, } from "../../stores/entity-store.js"; | ||
import { EntityStore, convertNormalizedEntityKeyToMap, isCompleteKey, normalizeCompositeKey, } from "../../stores/entity-store.js"; | ||
import { deserializeCompositeKey, serializeCompositeKey } from "../../utils.js"; | ||
@@ -22,6 +22,7 @@ import { paginateItems } from "./pagination.js"; | ||
const newVersion = options?.incrementVersion === false ? version : version + 1; | ||
this.getPartitionMap(entity, key.partition).set(key.sort?.keyValue ?? "default", { | ||
const newValue = { | ||
value, | ||
version: newVersion, | ||
}); | ||
}; | ||
setLocalEntity(this.getLocalEntity(entity), newValue, key, entity); | ||
this.props.localConnector.pushWorkflowTask({ | ||
@@ -46,13 +47,11 @@ entityName: entity.name, | ||
} | ||
if (!isCompleteKey(key)) { | ||
throw new Error("Entity key cannot be partial for delete"); | ||
if (deleteLocalEntity(this.getLocalEntity(entity), key, entity)) { | ||
this.props.localConnector.pushWorkflowTask({ | ||
entityName: entity.name, | ||
key: convertNormalizedEntityKeyToMap(key), | ||
operation: "remove", | ||
oldValue: item.value, | ||
oldVersion: item.version, | ||
}); | ||
} | ||
this.getPartitionMap(entity, key.partition).delete(key.sort?.keyValue ?? "default"); | ||
this.props.localConnector.pushWorkflowTask({ | ||
entityName: entity.name, | ||
key: convertNormalizedEntityKeyToMap(key), | ||
operation: "remove", | ||
oldValue: item.value, | ||
oldVersion: item.version, | ||
}); | ||
} | ||
@@ -124,8 +123,21 @@ } | ||
} | ||
getPartitionMap(entity, partitionKey) { | ||
const _entity = (this.entities[entity.name] ??= new Map()); | ||
let partitionMap = _entity.get(partitionKey.keyValue); | ||
getLocalEntity(entityOrIndex) { | ||
const entity = entityOrIndex.kind === "Entity" | ||
? entityOrIndex | ||
: this.getEntity(entityOrIndex.entityName); | ||
const _entity = (this.entities[entity.name] ??= | ||
initializeLocalEntity(entity)); | ||
return _entity; | ||
} | ||
getPartitionMap(entityOrIndex, partitionKey) { | ||
const index = entityOrIndex.kind === "EntityIndex" ? entityOrIndex : undefined; | ||
const _entity = this.getLocalEntity(entityOrIndex); | ||
const table = index ? _entity.indices[index.name] : _entity.data; | ||
if (!table) { | ||
throw new Error(`Index ${index?.name} not found`); | ||
} | ||
let partitionMap = table.get(partitionKey.keyValue); | ||
if (!partitionMap) { | ||
partitionMap = new Map(); | ||
_entity.set(partitionKey.keyValue, partitionMap); | ||
table.set(partitionKey.keyValue, partitionMap); | ||
} | ||
@@ -135,2 +147,61 @@ return partitionMap; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../../src/local/stores/entity-store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Entity,\n  Attributes,\n  EntityConsistencyOptions,\n  KeyValue,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityWithMetadata,\n  TransactionCancelled,\n  UnexpectedVersion,\n} from \"@eventual/core\";\nimport { assertNever } from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../../providers/entity-provider.js\";\nimport {\n  EntityStore,\n  NormalizedEntityCompositeKey,\n  NormalizedEntityCompositeKeyComplete,\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityTransactItem,\n  convertNormalizedEntityKeyToMap,\n  isCompleteKey,\n} from \"../../stores/entity-store.js\";\nimport { deserializeCompositeKey, serializeCompositeKey } from \"../../utils.js\";\nimport { LocalEnvConnector } from \"../local-container.js\";\nimport { paginateItems } from \"./pagination.js\";\n\nexport interface LocalEntityStoreProps {\n  localConnector: LocalEnvConnector;\n  entityProvider: EntityProvider;\n}\n\nexport class LocalEntityStore extends EntityStore {\n  private entities: Record<\n    string,\n    Map<KeyValue, Map<KeyValue, EntityWithMetadata>>\n  > = {};\n\n  constructor(private props: LocalEntityStoreProps) {\n    super(props.entityProvider);\n  }\n\n  protected override async _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined> {\n    return this.getPartitionMap(entity, key.partition).get(\n      key.sort?.keyValue ?? \"default\"\n    );\n  }\n\n  protected override async _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const { version = 0, value: oldValue } =\n      (await this._getWithMetadata(entity, key)) ?? {};\n    if (\n      options?.expectedVersion !== undefined &&\n      options.expectedVersion !== version\n    ) {\n      throw new Error(\n        `Expected entity to be of version ${options.expectedVersion} but found ${version}`\n      );\n    }\n    const newVersion =\n      options?.incrementVersion === false ? version : version + 1;\n\n    this.getPartitionMap(entity, key.partition).set(\n      key.sort?.keyValue ?? \"default\",\n      {\n        value,\n        version: newVersion,\n      }\n    );\n    this.props.localConnector.pushWorkflowTask({\n      entityName: entity.name,\n      key: convertNormalizedEntityKeyToMap(key),\n      operation: version === 0 ? (\"insert\" as const) : (\"modify\" as const),\n      newValue: value,\n      newVersion,\n      oldValue,\n      oldVersion: version,\n    });\n    return { version: newVersion };\n  }\n\n  protected override async _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const item = await this._getWithMetadata(entity, key);\n    if (item) {\n      if (options?.expectedVersion !== undefined) {\n        if (options.expectedVersion !== item.version) {\n          throw new UnexpectedVersion(\"Unexpected Version\");\n        }\n      }\n\n      if (!isCompleteKey(key)) {\n        throw new Error(\"Entity key cannot be partial for delete\");\n      }\n\n      this.getPartitionMap(entity, key.partition).delete(\n        key.sort?.keyValue ?? \"default\"\n      );\n      this.props.localConnector.pushWorkflowTask({\n        entityName: entity.name,\n        key: convertNormalizedEntityKeyToMap(key),\n        operation: \"remove\" as const,\n        oldValue: item.value,\n        oldVersion: item.version,\n      });\n    }\n  }\n\n  protected override async _query(\n    entity: Entity,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options?: EntityQueryOptions\n  ): Promise<EntityQueryResult> {\n    const partition = this.getPartitionMap(entity, queryKey.partition);\n    const entries = partition ? [...partition.entries()] : [];\n\n    const { items, nextToken } = paginateItems(\n      entries,\n      (a, b) =>\n        typeof a[0] === \"string\"\n          ? a[0].localeCompare(b[0] as string)\n          : typeof a[0] === \"number\"\n          ? a[0] - (b[0] as number)\n          : 0,\n      undefined,\n      undefined,\n      options?.limit,\n      options?.nextToken\n    );\n\n    // values should be sorted\n    return {\n      entries: items?.map(\n        ([, value]) =>\n          ({\n            value: value.value,\n            version: value.version,\n          } satisfies EntityWithMetadata)\n      ),\n      nextToken,\n    };\n  }\n\n  protected override async _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void> {\n    const keysAndVersions = Object.fromEntries(\n      items.map((item) => {\n        return [\n          serializeCompositeKey(item.entity.name, item.key),\n          item.operation === \"condition\"\n            ? item.version\n            : item.options?.expectedVersion,\n        ] as const;\n      })\n    );\n    /**\n     * Evaluate the expected versions against the current state and return the results.\n     *\n     * This is similar to calling TransactWriteItem in dynamo with only ConditionChecks and then\n     * handling the errors.\n     */\n    const consistencyResults = await Promise.all(\n      Object.entries(keysAndVersions).map(async ([sKey, expectedVersion]) => {\n        if (expectedVersion === undefined) {\n          return true;\n        }\n        const [entityName, key] = deserializeCompositeKey(sKey);\n        const { version } = (await this.getWithMetadata(entityName, key)) ?? {\n          version: 0,\n        };\n        return version === expectedVersion;\n      })\n    );\n    if (consistencyResults.some((r) => !r)) {\n      throw new TransactionCancelled(\n        consistencyResults.map((r) =>\n          r ? undefined : new UnexpectedVersion(\"Unexpected Version\")\n        )\n      );\n    }\n    /**\n     * After ensuring that all of the expected versions are accurate, actually perform the writes.\n     * Here we assume that the write operations are synchronous and that\n     * the state of the condition checks will not be invalided.\n     */\n    await Promise.all(\n      items.map(async (item) => {\n        if (item.operation === \"set\") {\n          return await this._set(\n            item.entity,\n            item.value,\n            item.key,\n            item.options\n          );\n        } else if (item.operation === \"delete\") {\n          return await this._delete(item.entity, item.key, item.options);\n        } else if (item.operation === \"condition\") {\n          // no op\n          return;\n        }\n        return assertNever(item);\n      })\n    );\n  }\n\n  private getPartitionMap(\n    entity: Entity,\n    partitionKey: NormalizedEntityKeyCompletePart\n  ) {\n    const _entity = (this.entities[entity.name] ??= new Map<\n      KeyValue,\n      Map<KeyValue, EntityWithMetadata>\n    >());\n    let partitionMap = _entity.get(partitionKey.keyValue);\n    if (!partitionMap) {\n      partitionMap = new Map<KeyValue, EntityWithMetadata>();\n      _entity.set(partitionKey.keyValue, partitionMap);\n    }\n    return partitionMap;\n  }\n}\n"]} | ||
function initializeLocalEntity(entity) { | ||
return { | ||
data: new Map(), | ||
indices: Object.fromEntries(entity.indices.map((i) => [ | ||
i.name, | ||
new Map(), | ||
])), | ||
}; | ||
} | ||
function setLocalEntity(localEntity, value, key, entity) { | ||
updatePartitionEntry(localEntity.data, key, value); | ||
entity.indices.forEach((i) => { | ||
const localIndex = localEntity.indices[i.name]; | ||
if (!localIndex) { | ||
return; | ||
} | ||
const normalizedKey = normalizeCompositeKey(i.key, value.value); | ||
// if the key isn't complete (missing parts of the index composite key), ignore this item | ||
if (isCompleteKey(normalizedKey)) { | ||
updatePartitionEntry(localIndex, normalizedKey, value); | ||
} | ||
}); | ||
function updatePartitionEntry(store, key, value) { | ||
let partitionMap = store.get(key.partition.keyValue); | ||
if (!partitionMap) { | ||
partitionMap = new Map(); | ||
store.set(key.partition.keyValue, partitionMap); | ||
} | ||
partitionMap.set(key.sort?.keyValue ?? "default", value); | ||
} | ||
} | ||
function deleteLocalEntity(localEntity, key, entity) { | ||
const value = localEntity.data | ||
.get(key.partition.keyValue) | ||
?.get(key.sort?.keyValue ?? "default"); | ||
if (!value) { | ||
return false; | ||
} | ||
const deleted = deletePartitionEntry(localEntity.data, key); | ||
entity.indices.forEach((i) => { | ||
const localIndex = localEntity.indices[i.name]; | ||
if (!localIndex) { | ||
return; | ||
} | ||
const normalizedKey = normalizeCompositeKey(i.key, value.value); | ||
// if the key isn't complete (missing parts of the index composite key), ignore this item | ||
if (isCompleteKey(normalizedKey)) { | ||
deletePartitionEntry(localIndex, normalizedKey); | ||
} | ||
}); | ||
return deleted; | ||
function deletePartitionEntry(store, key) { | ||
const partitionMap = store.get(key.partition.keyValue); | ||
if (partitionMap) { | ||
return partitionMap.delete(key.sort?.keyValue ?? "default"); | ||
} | ||
return false; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../../src/local/stores/entity-store.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Attributes,\n  Entity,\n  EntityConsistencyOptions,\n  EntityIndex,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityWithMetadata,\n  KeyValue,\n  TransactionCancelled,\n  UnexpectedVersion,\n} from \"@eventual/core\";\nimport { assertNever } from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../../providers/entity-provider.js\";\nimport {\n  EntityStore,\n  NormalizedEntityCompositeKey,\n  NormalizedEntityCompositeKeyComplete,\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityTransactItem,\n  convertNormalizedEntityKeyToMap,\n  isCompleteKey,\n  normalizeCompositeKey,\n} from \"../../stores/entity-store.js\";\nimport { deserializeCompositeKey, serializeCompositeKey } from \"../../utils.js\";\nimport { LocalEnvConnector } from \"../local-container.js\";\nimport { paginateItems } from \"./pagination.js\";\n\nexport interface LocalEntityStoreProps {\n  localConnector: LocalEnvConnector;\n  entityProvider: EntityProvider;\n}\n\nexport interface LocalEntity {\n  data: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>;\n  indices: Record<string, Map<KeyValue, Map<KeyValue, EntityWithMetadata>>>;\n}\n\nexport class LocalEntityStore extends EntityStore {\n  private entities: Record<string, LocalEntity> = {};\n\n  constructor(private props: LocalEntityStoreProps) {\n    super(props.entityProvider);\n  }\n\n  protected override async _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined> {\n    return this.getPartitionMap(entity, key.partition).get(\n      key.sort?.keyValue ?? \"default\"\n    );\n  }\n\n  protected override async _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const { version = 0, value: oldValue } =\n      (await this._getWithMetadata(entity, key)) ?? {};\n    if (\n      options?.expectedVersion !== undefined &&\n      options.expectedVersion !== version\n    ) {\n      throw new Error(\n        `Expected entity to be of version ${options.expectedVersion} but found ${version}`\n      );\n    }\n    const newVersion =\n      options?.incrementVersion === false ? version : version + 1;\n\n    const newValue = {\n      value,\n      version: newVersion,\n    };\n\n    setLocalEntity(this.getLocalEntity(entity), newValue, key, entity);\n\n    this.props.localConnector.pushWorkflowTask({\n      entityName: entity.name,\n      key: convertNormalizedEntityKeyToMap(key),\n      operation: version === 0 ? (\"insert\" as const) : (\"modify\" as const),\n      newValue: value,\n      newVersion,\n      oldValue,\n      oldVersion: version,\n    });\n    return { version: newVersion };\n  }\n\n  protected override async _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const item = await this._getWithMetadata(entity, key);\n    if (item) {\n      if (options?.expectedVersion !== undefined) {\n        if (options.expectedVersion !== item.version) {\n          throw new UnexpectedVersion(\"Unexpected Version\");\n        }\n      }\n\n      if (deleteLocalEntity(this.getLocalEntity(entity), key, entity)) {\n        this.props.localConnector.pushWorkflowTask({\n          entityName: entity.name,\n          key: convertNormalizedEntityKeyToMap(key),\n          operation: \"remove\" as const,\n          oldValue: item.value,\n          oldVersion: item.version,\n        });\n      }\n    }\n  }\n\n  protected override async _query(\n    entity: Entity | EntityIndex,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options?: EntityQueryOptions\n  ): Promise<EntityQueryResult> {\n    const partition = this.getPartitionMap(entity, queryKey.partition);\n    const entries = partition ? [...partition.entries()] : [];\n\n    const { items, nextToken } = paginateItems(\n      entries,\n      (a, b) =>\n        typeof a[0] === \"string\"\n          ? a[0].localeCompare(b[0] as string)\n          : typeof a[0] === \"number\"\n          ? a[0] - (b[0] as number)\n          : 0,\n      undefined,\n      undefined,\n      options?.limit,\n      options?.nextToken\n    );\n\n    // values should be sorted\n    return {\n      entries: items?.map(\n        ([, value]) =>\n          ({\n            value: value.value,\n            version: value.version,\n          } satisfies EntityWithMetadata)\n      ),\n      nextToken,\n    };\n  }\n\n  protected override async _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void> {\n    const keysAndVersions = Object.fromEntries(\n      items.map((item) => {\n        return [\n          serializeCompositeKey(item.entity.name, item.key),\n          item.operation === \"condition\"\n            ? item.version\n            : item.options?.expectedVersion,\n        ] as const;\n      })\n    );\n    /**\n     * Evaluate the expected versions against the current state and return the results.\n     *\n     * This is similar to calling TransactWriteItem in dynamo with only ConditionChecks and then\n     * handling the errors.\n     */\n    const consistencyResults = await Promise.all(\n      Object.entries(keysAndVersions).map(async ([sKey, expectedVersion]) => {\n        if (expectedVersion === undefined) {\n          return true;\n        }\n        const [entityName, key] = deserializeCompositeKey(sKey);\n        const { version } = (await this.getWithMetadata(entityName, key)) ?? {\n          version: 0,\n        };\n        return version === expectedVersion;\n      })\n    );\n    if (consistencyResults.some((r) => !r)) {\n      throw new TransactionCancelled(\n        consistencyResults.map((r) =>\n          r ? undefined : new UnexpectedVersion(\"Unexpected Version\")\n        )\n      );\n    }\n    /**\n     * After ensuring that all of the expected versions are accurate, actually perform the writes.\n     * Here we assume that the write operations are synchronous and that\n     * the state of the condition checks will not be invalided.\n     */\n    await Promise.all(\n      items.map(async (item) => {\n        if (item.operation === \"set\") {\n          return await this._set(\n            item.entity,\n            item.value,\n            item.key,\n            item.options\n          );\n        } else if (item.operation === \"delete\") {\n          return await this._delete(item.entity, item.key, item.options);\n        } else if (item.operation === \"condition\") {\n          // no op\n          return;\n        }\n        return assertNever(item);\n      })\n    );\n  }\n\n  private getLocalEntity(entityOrIndex: Entity | EntityIndex) {\n    const entity =\n      entityOrIndex.kind === \"Entity\"\n        ? entityOrIndex\n        : this.getEntity(entityOrIndex.entityName);\n    const _entity = (this.entities[entity.name] ??=\n      initializeLocalEntity(entity));\n    return _entity;\n  }\n\n  private getPartitionMap(\n    entityOrIndex: Entity | EntityIndex,\n    partitionKey: NormalizedEntityKeyCompletePart\n  ) {\n    const index =\n      entityOrIndex.kind === \"EntityIndex\" ? entityOrIndex : undefined;\n    const _entity = this.getLocalEntity(entityOrIndex);\n    const table = index ? _entity.indices[index.name] : _entity.data;\n    if (!table) {\n      throw new Error(`Index ${index?.name} not found`);\n    }\n    let partitionMap = table.get(partitionKey.keyValue);\n    if (!partitionMap) {\n      partitionMap = new Map<KeyValue, EntityWithMetadata>();\n      table.set(partitionKey.keyValue, partitionMap);\n    }\n    return partitionMap;\n  }\n}\n\nfunction initializeLocalEntity(entity: Entity): LocalEntity {\n  return {\n    data: new Map<KeyValue, Map<KeyValue, EntityWithMetadata>>(),\n    indices: Object.fromEntries(\n      entity.indices.map((i) => [\n        i.name,\n        new Map<KeyValue, Map<KeyValue, EntityWithMetadata>>(),\n      ])\n    ),\n  };\n}\n\nfunction setLocalEntity(\n  localEntity: LocalEntity,\n  value: EntityWithMetadata,\n  key: NormalizedEntityCompositeKeyComplete,\n  entity: Entity\n) {\n  updatePartitionEntry(localEntity.data, key, value);\n\n  entity.indices.forEach((i) => {\n    const localIndex = localEntity.indices[i.name];\n    if (!localIndex) {\n      return;\n    }\n    const normalizedKey = normalizeCompositeKey(i.key, value.value);\n\n    // if the key isn't complete (missing parts of the index composite key), ignore this item\n    if (isCompleteKey(normalizedKey)) {\n      updatePartitionEntry(localIndex, normalizedKey, value);\n    }\n  });\n\n  function updatePartitionEntry(\n    store: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>,\n    key: NormalizedEntityCompositeKeyComplete,\n    value: EntityWithMetadata\n  ) {\n    let partitionMap = store.get(key.partition.keyValue);\n    if (!partitionMap) {\n      partitionMap = new Map<KeyValue, EntityWithMetadata>();\n      store.set(key.partition.keyValue, partitionMap);\n    }\n    partitionMap.set(key.sort?.keyValue ?? \"default\", value);\n  }\n}\n\nfunction deleteLocalEntity(\n  localEntity: LocalEntity,\n  key: NormalizedEntityCompositeKeyComplete,\n  entity: Entity\n): boolean {\n  const value = localEntity.data\n    .get(key.partition.keyValue)\n    ?.get(key.sort?.keyValue ?? \"default\");\n\n  if (!value) {\n    return false;\n  }\n\n  const deleted = deletePartitionEntry(localEntity.data, key);\n\n  entity.indices.forEach((i) => {\n    const localIndex = localEntity.indices[i.name];\n    if (!localIndex) {\n      return;\n    }\n    const normalizedKey = normalizeCompositeKey(i.key, value.value);\n\n    // if the key isn't complete (missing parts of the index composite key), ignore this item\n    if (isCompleteKey(normalizedKey)) {\n      deletePartitionEntry(localIndex, normalizedKey);\n    }\n  });\n\n  return deleted;\n\n  function deletePartitionEntry(\n    store: Map<KeyValue, Map<KeyValue, EntityWithMetadata>>,\n    key: NormalizedEntityCompositeKeyComplete\n  ) {\n    const partitionMap = store.get(key.partition.keyValue);\n    if (partitionMap) {\n      return partitionMap.delete(key.sort?.keyValue ?? \"default\");\n    }\n    return false;\n  }\n}\n"]} |
@@ -1,2 +0,2 @@ | ||
import type { Entity, Attributes, CompositeKey, EntityConsistencyOptions, KeyMap, KeyValue, QueryKey, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityTransactItem, EntityWithMetadata } from "@eventual/core"; | ||
import type { Entity, Attributes, CompositeKey, EntityConsistencyOptions, KeyMap, KeyValue, QueryKey, EntityQueryOptions, EntityQueryResult, EntitySetOptions, EntityTransactItem, EntityWithMetadata, EntityIndex } from "@eventual/core"; | ||
import type { EntityHook, KeyDefinition, KeyDefinitionPart } from "@eventual/core/internal"; | ||
@@ -19,3 +19,4 @@ import { EntityProvider } from "../providers/entity-provider.js"; | ||
query(entityName: string, queryKey: QueryKey, options?: EntityQueryOptions | undefined): Promise<EntityQueryResult>; | ||
protected abstract _query(entity: Entity, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options: EntityQueryOptions | undefined): Promise<EntityQueryResult>; | ||
queryIndex(entityName: string, indexName: string, queryKey: QueryKey, options?: EntityQueryOptions | undefined): Promise<EntityQueryOptions>; | ||
protected abstract _query(entity: Entity | EntityIndex, queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>, options: EntityQueryOptions | undefined): Promise<EntityQueryResult>; | ||
transactWrite(items: EntityTransactItem[]): Promise<void>; | ||
@@ -22,0 +23,0 @@ protected abstract _transactWrite(items: NormalizedEntityTransactItem[]): Promise<void>; |
@@ -40,2 +40,13 @@ export class EntityStore { | ||
} | ||
queryIndex(entityName, indexName, queryKey, options) { | ||
const index = this.getEntity(entityName).indices.find((i) => i.name === indexName); | ||
if (!index) { | ||
throw new Error(`Index ${indexName} was not found on entity ${entityName}`); | ||
} | ||
const normalizedKey = normalizeCompositeKey(index.key, queryKey); | ||
if (!isCompleteKeyPart(normalizedKey.partition)) { | ||
throw new Error("Entity Index partition key cannot be partial for query."); | ||
} | ||
return this._query(index, normalizedKey, options); | ||
} | ||
async transactWrite(items) { | ||
@@ -139,2 +150,2 @@ return this._transactWrite(items.map((item) => { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../src/stores/entity-store.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  Entity,\n  Attributes,\n  CompositeKey,\n  EntityConsistencyOptions,\n  KeyMap,\n  KeyValue,\n  QueryKey,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityTransactItem,\n  EntityWithMetadata,\n} from \"@eventual/core\";\nimport type {\n  EntityHook,\n  KeyDefinition,\n  KeyDefinitionPart,\n} from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../providers/entity-provider.js\";\n\nexport abstract class EntityStore implements EntityHook {\n  constructor(private entityProvider: EntityProvider) {}\n\n  public async get(entityName: string, key: CompositeKey): Promise<any> {\n    return (await this.getWithMetadata(entityName, key))?.value;\n  }\n\n  public async getWithMetadata(\n    entityName: string,\n    key: CompositeKey\n  ): Promise<EntityWithMetadata | undefined> {\n    const entity = this.getEntity(entityName);\n    const normalizedCompositeKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedCompositeKey)) {\n      throw new Error(\"Key cannot be partial for get or getWithMetadata.\");\n    }\n\n    return this._getWithMetadata(entity, normalizedCompositeKey);\n  }\n\n  protected abstract _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined>;\n\n  public set(\n    entityName: string,\n    value: Attributes,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, value);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for set.\");\n    }\n\n    return this._set(entity, value, normalizedKey, options);\n  }\n\n  protected abstract _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }>;\n\n  public delete(\n    entityName: string,\n    key: CompositeKey,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for delete.\");\n    }\n\n    return this._delete(entity, normalizedKey, options);\n  }\n\n  protected abstract _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void>;\n\n  public query(\n    entityName: string,\n    queryKey: QueryKey,\n    options?: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, queryKey);\n\n    if (!isCompleteKeyPart(normalizedKey.partition)) {\n      throw new Error(\"Entity partition key cannot be partial for query\");\n    }\n\n    return this._query(\n      entity,\n      normalizedKey as NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n      options\n    );\n  }\n\n  protected abstract _query(\n    entity: Entity,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult>;\n\n  public async transactWrite(items: EntityTransactItem[]): Promise<void> {\n    return this._transactWrite(\n      items.map((item): NormalizedEntityTransactItem => {\n        const entity =\n          typeof item.entity === \"string\"\n            ? this.getEntity(item.entity)\n            : item.entity;\n        const keyValue = item.operation === \"set\" ? item.value : item.key;\n        const key = normalizeCompositeKey(entity, keyValue);\n        if (!isCompleteKey(key)) {\n          throw new Error(\n            \"Entity key cannot be partial for set, delete, or condition operations.\"\n          );\n        }\n\n        return item.operation === \"set\"\n          ? {\n              operation: \"set\",\n              entity,\n              key,\n              value: item.value,\n              options: item.options,\n            }\n          : item.operation === \"delete\"\n          ? {\n              operation: \"delete\",\n              entity,\n              key,\n              options: item.options,\n            }\n          : {\n              operation: \"condition\",\n              entity,\n              key,\n              version: item.version,\n            };\n      })\n    );\n  }\n\n  protected abstract _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void>;\n\n  protected getEntity(entityName: string) {\n    const entity = this.entityProvider.getEntity(entityName);\n\n    if (!entity) {\n      throw new Error(`Entity ${entityName} was not found.`);\n    }\n    return entity;\n  }\n}\n\nexport type NormalizedEntityTransactItem = {\n  entity: Entity;\n  key: NormalizedEntityCompositeKeyComplete;\n} & (\n  | {\n      operation: \"set\";\n      value: Attributes;\n      options?: EntitySetOptions;\n    }\n  | {\n      operation: \"delete\";\n      options?: EntityConsistencyOptions;\n    }\n  | {\n      operation: \"condition\";\n      version?: number;\n    }\n);\n\nexport interface NormalizedEntityKeyPartBase extends KeyDefinitionPart {\n  parts: { field: string; value: KeyValue }[];\n}\n\nexport type NormalizedEntityKeyPart =\n  | NormalizedEntityKeyPartialPart\n  | NormalizedEntityKeyCompletePart;\n\nexport interface NormalizedEntityKeyCompletePart\n  extends NormalizedEntityKeyPartBase {\n  keyValue: string | number;\n  partialValue: false;\n}\n\nexport interface NormalizedEntityKeyPartialPart\n  extends NormalizedEntityKeyPartBase {\n  keyValue?: string | number;\n  partialValue: true;\n}\n\nexport function isCompleteKeyPart(\n  key: NormalizedEntityKeyPart\n): key is NormalizedEntityKeyCompletePart {\n  return !key.partialValue;\n}\n\nexport function isCompleteKey(\n  key: NormalizedEntityCompositeKey\n): key is NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n> {\n  return (\n    isCompleteKeyPart(key.partition) &&\n    (!key.sort || isCompleteKeyPart(key.sort))\n  );\n}\n\nexport interface NormalizedEntityCompositeKey<\n  Partition extends NormalizedEntityKeyPart = NormalizedEntityKeyPart,\n  Sort extends NormalizedEntityKeyPart = NormalizedEntityKeyPart\n> {\n  partition: Partition;\n  sort?: Sort;\n}\n\nexport type NormalizedEntityCompositeKeyComplete = NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n>;\n\n/**\n * Generate properties for an entity key given the key definition and key values.\n */\nexport function normalizeCompositeKey<E extends Entity>(\n  entity: E | KeyDefinition,\n  key: Partial<CompositeKey>\n): NormalizedEntityCompositeKey {\n  const keyDef = \"partition\" in entity ? entity : entity.key;\n\n  const partitionCompositeKey = formatNormalizedPart(keyDef.partition, (p, i) =>\n    Array.isArray(key) ? key[i] : (key as KeyMap)[p]\n  );\n\n  const sortCompositeKey = keyDef.sort\n    ? formatNormalizedPart(keyDef.sort, (p, i) =>\n        Array.isArray(key)\n          ? key[keyDef.partition.attributes.length + i]\n          : (key as KeyMap)[p]\n      )\n    : undefined;\n\n  return sortCompositeKey\n    ? {\n        partition: partitionCompositeKey,\n        sort: sortCompositeKey,\n      }\n    : {\n        partition: partitionCompositeKey,\n      };\n}\n\nfunction formatNormalizedPart(\n  keyPart: KeyDefinitionPart,\n  valueRetriever: (field: string, index: number) => string | number\n): NormalizedEntityKeyPart {\n  const parts = keyPart.attributes.map((p, i) => ({\n    field: p,\n    value: valueRetriever(p, i),\n  }));\n\n  const missingValueIndex = parts.findIndex((p) => p.value === undefined);\n\n  return {\n    type: keyPart.type,\n    attributes: keyPart.attributes,\n    parts,\n    keyAttribute: keyPart.keyAttribute,\n    keyValue: (keyPart.type === \"number\"\n      ? parts[0]?.value\n      : (missingValueIndex === -1 ? parts : parts.slice(0, missingValueIndex))\n          .map((p) => p.value)\n          .join(\"#\")) as any,\n    partialValue: missingValueIndex !== -1,\n  };\n}\n\nexport function convertNormalizedEntityKeyToMap(\n  key: NormalizedEntityCompositeKey\n): KeyMap<any, any, any> {\n  console.log(\"input key\", JSON.stringify(key));\n  const generatedKey = Object.fromEntries([\n    ...key.partition.parts.map(({ field, value }) => [field, value]),\n    ...(key.sort\n      ? key.sort.parts.map(({ field, value }) => [field, value])\n      : []),\n  ]);\n  console.log(\"generated key\", JSON.stringify(generatedKey));\n  return generatedKey;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-store.js","sourceRoot":"","sources":["../../../src/stores/entity-store.ts"],"names":[],"mappings":"AAsBA,MAAM,OAAgB,WAAW;IAC/B,YAAoB,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;IAAG,CAAC;IAE/C,KAAK,CAAC,GAAG,CAAC,UAAkB,EAAE,GAAiB;QACpD,OAAO,CAAC,MAAM,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;IAC9D,CAAC;IAEM,KAAK,CAAC,eAAe,CAC1B,UAAkB,EAClB,GAAiB;QAEjB,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,MAAM,sBAAsB,GAAG,qBAAqB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAElE,IAAI,CAAC,aAAa,CAAC,sBAAsB,CAAC,EAAE;YAC1C,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;SACtE;QAED,OAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,sBAAsB,CAAC,CAAC;IAC/D,CAAC;IAOM,GAAG,CACR,UAAkB,EAClB,KAAiB,EACjB,OAA0B;QAE1B,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,MAAM,aAAa,GAAG,qBAAqB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAE3D,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;SACnD;QAED,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;IAC1D,CAAC;IASM,MAAM,CACX,UAAkB,EAClB,GAAiB,EACjB,OAA8C;QAE9C,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,MAAM,aAAa,GAAG,qBAAqB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAEzD,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;SACtD;QAED,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;IACtD,CAAC;IAQM,KAAK,CACV,UAAkB,EAClB,QAAkB,EAClB,OAAwC;QAExC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,MAAM,aAAa,GAAG,qBAAqB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAE9D,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE;YAC/C,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;SACrE;QAED,OAAO,IAAI,CAAC,MAAM,CAChB,MAAM,EACN,aAA8E,EAC9E,OAAO,CACR,CAAC;IACJ,CAAC;IAEM,UAAU,CACf,UAAkB,EAClB,SAAiB,EACjB,QAAkB,EAClB,OAAwC;QAExC,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,IAAI,CACnD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,SAAS,CAC5B,CAAC;QAEF,IAAI,CAAC,KAAK,EAAE;YACV,MAAM,IAAI,KAAK,CACb,SAAS,SAAS,4BAA4B,UAAU,EAAE,CAC3D,CAAC;SACH;QAED,MAAM,aAAa,GAAG,qBAAqB,CAAC,KAAK,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAEjE,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE;YAC/C,MAAM,IAAI,KAAK,CACb,yDAAyD,CAC1D,CAAC;SACH;QAED,OAAO,IAAI,CAAC,MAAM,CAChB,KAAK,EACL,aAA8E,EAC9E,OAAO,CACR,CAAC;IACJ,CAAC;IAQM,KAAK,CAAC,aAAa,CAAC,KAA2B;QACpD,OAAO,IAAI,CAAC,cAAc,CACxB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAgC,EAAE;YAC/C,MAAM,MAAM,GACV,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ;gBAC7B,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC7B,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;YAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;YAClE,MAAM,GAAG,GAAG,qBAAqB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YACpD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE;gBACvB,MAAM,IAAI,KAAK,CACb,wEAAwE,CACzE,CAAC;aACH;YAED,OAAO,IAAI,CAAC,SAAS,KAAK,KAAK;gBAC7B,CAAC,CAAC;oBACE,SAAS,EAAE,KAAK;oBAChB,MAAM;oBACN,GAAG;oBACH,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,OAAO,EAAE,IAAI,CAAC,OAAO;iBACtB;gBACH,CAAC,CAAC,IAAI,CAAC,SAAS,KAAK,QAAQ;oBAC7B,CAAC,CAAC;wBACE,SAAS,EAAE,QAAQ;wBACnB,MAAM;wBACN,GAAG;wBACH,OAAO,EAAE,IAAI,CAAC,OAAO;qBACtB;oBACH,CAAC,CAAC;wBACE,SAAS,EAAE,WAAW;wBACtB,MAAM;wBACN,GAAG;wBACH,OAAO,EAAE,IAAI,CAAC,OAAO;qBACtB,CAAC;QACR,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAMS,SAAS,CAAC,UAAkB;QACpC,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAEzD,IAAI,CAAC,MAAM,EAAE;YACX,MAAM,IAAI,KAAK,CAAC,UAAU,UAAU,iBAAiB,CAAC,CAAC;SACxD;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAyCD,MAAM,UAAU,iBAAiB,CAC/B,GAA4B;IAE5B,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,GAAiC;IAKjC,OAAO,CACL,iBAAiB,CAAC,GAAG,CAAC,SAAS,CAAC;QAChC,CAAC,CAAC,GAAG,CAAC,IAAI,IAAI,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAC3C,CAAC;AACJ,CAAC;AAeD;;GAEG;AACH,MAAM,UAAU,qBAAqB,CACnC,MAAyB,EACzB,GAA0B;IAE1B,MAAM,MAAM,GAAG,WAAW,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC;IAE3D,MAAM,qBAAqB,GAAG,oBAAoB,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAC5E,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,CACjD,CAAC;IAEF,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI;QAClC,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACzC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC;YAChB,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC;YAC7C,CAAC,CAAE,GAAc,CAAC,CAAC,CAAC,CACvB;QACH,CAAC,CAAC,SAAS,CAAC;IAEd,OAAO,gBAAgB;QACrB,CAAC,CAAC;YACE,SAAS,EAAE,qBAAqB;YAChC,IAAI,EAAE,gBAAgB;SACvB;QACH,CAAC,CAAC;YACE,SAAS,EAAE,qBAAqB;SACjC,CAAC;AACR,CAAC;AAED,SAAS,oBAAoB,CAC3B,OAA0B,EAC1B,cAAiE;IAEjE,MAAM,KAAK,GAAG,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAC9C,KAAK,EAAE,CAAC;QACR,KAAK,EAAE,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC;KAC5B,CAAC,CAAC,CAAC;IAEJ,MAAM,iBAAiB,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC;IAExE,OAAO;QACL,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,UAAU,EAAE,OAAO,CAAC,UAAU;QAC9B,KAAK;QACL,YAAY,EAAE,OAAO,CAAC,YAAY;QAClC,QAAQ,EAAE,CAAC,OAAO,CAAC,IAAI,KAAK,QAAQ;YAClC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK;YACjB,CAAC,CAAC,CAAC,iBAAiB,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC;iBACnE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;iBACnB,IAAI,CAAC,GAAG,CAAC,CAAQ;QACxB,YAAY,EAAE,iBAAiB,KAAK,CAAC,CAAC;KACvC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,+BAA+B,CAC7C,GAAiC;IAEjC,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9C,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACtC,GAAG,GAAG,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAChE,GAAG,CAAC,GAAG,CAAC,IAAI;YACV,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YAC1D,CAAC,CAAC,EAAE,CAAC;KACR,CAAC,CAAC;IACH,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC;IAC3D,OAAO,YAAY,CAAC;AACtB,CAAC","sourcesContent":["import type {\n  Entity,\n  Attributes,\n  CompositeKey,\n  EntityConsistencyOptions,\n  KeyMap,\n  KeyValue,\n  QueryKey,\n  EntityQueryOptions,\n  EntityQueryResult,\n  EntitySetOptions,\n  EntityTransactItem,\n  EntityWithMetadata,\n  EntityIndex,\n} from \"@eventual/core\";\nimport type {\n  EntityHook,\n  KeyDefinition,\n  KeyDefinitionPart,\n} from \"@eventual/core/internal\";\nimport { EntityProvider } from \"../providers/entity-provider.js\";\n\nexport abstract class EntityStore implements EntityHook {\n  constructor(private entityProvider: EntityProvider) {}\n\n  public async get(entityName: string, key: CompositeKey): Promise<any> {\n    return (await this.getWithMetadata(entityName, key))?.value;\n  }\n\n  public async getWithMetadata(\n    entityName: string,\n    key: CompositeKey\n  ): Promise<EntityWithMetadata | undefined> {\n    const entity = this.getEntity(entityName);\n    const normalizedCompositeKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedCompositeKey)) {\n      throw new Error(\"Key cannot be partial for get or getWithMetadata.\");\n    }\n\n    return this._getWithMetadata(entity, normalizedCompositeKey);\n  }\n\n  protected abstract _getWithMetadata(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete\n  ): Promise<EntityWithMetadata | undefined>;\n\n  public set(\n    entityName: string,\n    value: Attributes,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, value);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for set.\");\n    }\n\n    return this._set(entity, value, normalizedKey, options);\n  }\n\n  protected abstract _set(\n    entity: Entity,\n    value: Attributes,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntitySetOptions\n  ): Promise<{ version: number }>;\n\n  public delete(\n    entityName: string,\n    key: CompositeKey,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, key);\n\n    if (!isCompleteKey(normalizedKey)) {\n      throw new Error(\"Key cannot be partial for delete.\");\n    }\n\n    return this._delete(entity, normalizedKey, options);\n  }\n\n  protected abstract _delete(\n    entity: Entity,\n    key: NormalizedEntityCompositeKeyComplete,\n    options?: EntityConsistencyOptions | undefined\n  ): Promise<void>;\n\n  public query(\n    entityName: string,\n    queryKey: QueryKey,\n    options?: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult> {\n    const entity = this.getEntity(entityName);\n    const normalizedKey = normalizeCompositeKey(entity, queryKey);\n\n    if (!isCompleteKeyPart(normalizedKey.partition)) {\n      throw new Error(\"Entity partition key cannot be partial for query\");\n    }\n\n    return this._query(\n      entity,\n      normalizedKey as NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n      options\n    );\n  }\n\n  public queryIndex(\n    entityName: string,\n    indexName: string,\n    queryKey: QueryKey,\n    options?: EntityQueryOptions | undefined\n  ): Promise<EntityQueryOptions> {\n    const index = this.getEntity(entityName).indices.find(\n      (i) => i.name === indexName\n    );\n\n    if (!index) {\n      throw new Error(\n        `Index ${indexName} was not found on entity ${entityName}`\n      );\n    }\n\n    const normalizedKey = normalizeCompositeKey(index.key, queryKey);\n\n    if (!isCompleteKeyPart(normalizedKey.partition)) {\n      throw new Error(\n        \"Entity Index partition key cannot be partial for query.\"\n      );\n    }\n\n    return this._query(\n      index,\n      normalizedKey as NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n      options\n    );\n  }\n\n  protected abstract _query(\n    entity: Entity | EntityIndex,\n    queryKey: NormalizedEntityCompositeKey<NormalizedEntityKeyCompletePart>,\n    options: EntityQueryOptions | undefined\n  ): Promise<EntityQueryResult>;\n\n  public async transactWrite(items: EntityTransactItem[]): Promise<void> {\n    return this._transactWrite(\n      items.map((item): NormalizedEntityTransactItem => {\n        const entity =\n          typeof item.entity === \"string\"\n            ? this.getEntity(item.entity)\n            : item.entity;\n        const keyValue = item.operation === \"set\" ? item.value : item.key;\n        const key = normalizeCompositeKey(entity, keyValue);\n        if (!isCompleteKey(key)) {\n          throw new Error(\n            \"Entity key cannot be partial for set, delete, or condition operations.\"\n          );\n        }\n\n        return item.operation === \"set\"\n          ? {\n              operation: \"set\",\n              entity,\n              key,\n              value: item.value,\n              options: item.options,\n            }\n          : item.operation === \"delete\"\n          ? {\n              operation: \"delete\",\n              entity,\n              key,\n              options: item.options,\n            }\n          : {\n              operation: \"condition\",\n              entity,\n              key,\n              version: item.version,\n            };\n      })\n    );\n  }\n\n  protected abstract _transactWrite(\n    items: NormalizedEntityTransactItem[]\n  ): Promise<void>;\n\n  protected getEntity(entityName: string) {\n    const entity = this.entityProvider.getEntity(entityName);\n\n    if (!entity) {\n      throw new Error(`Entity ${entityName} was not found.`);\n    }\n    return entity;\n  }\n}\n\nexport type NormalizedEntityTransactItem = {\n  entity: Entity;\n  key: NormalizedEntityCompositeKeyComplete;\n} & (\n  | {\n      operation: \"set\";\n      value: Attributes;\n      options?: EntitySetOptions;\n    }\n  | {\n      operation: \"delete\";\n      options?: EntityConsistencyOptions;\n    }\n  | {\n      operation: \"condition\";\n      version?: number;\n    }\n);\n\nexport interface NormalizedEntityKeyPartBase extends KeyDefinitionPart {\n  parts: { field: string; value: KeyValue }[];\n}\n\nexport type NormalizedEntityKeyPart =\n  | NormalizedEntityKeyPartialPart\n  | NormalizedEntityKeyCompletePart;\n\nexport interface NormalizedEntityKeyCompletePart\n  extends NormalizedEntityKeyPartBase {\n  keyValue: string | number;\n  partialValue: false;\n}\n\nexport interface NormalizedEntityKeyPartialPart\n  extends NormalizedEntityKeyPartBase {\n  keyValue?: string | number;\n  partialValue: true;\n}\n\nexport function isCompleteKeyPart(\n  key: NormalizedEntityKeyPart\n): key is NormalizedEntityKeyCompletePart {\n  return !key.partialValue;\n}\n\nexport function isCompleteKey(\n  key: NormalizedEntityCompositeKey\n): key is NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n> {\n  return (\n    isCompleteKeyPart(key.partition) &&\n    (!key.sort || isCompleteKeyPart(key.sort))\n  );\n}\n\nexport interface NormalizedEntityCompositeKey<\n  Partition extends NormalizedEntityKeyPart = NormalizedEntityKeyPart,\n  Sort extends NormalizedEntityKeyPart = NormalizedEntityKeyPart\n> {\n  partition: Partition;\n  sort?: Sort;\n}\n\nexport type NormalizedEntityCompositeKeyComplete = NormalizedEntityCompositeKey<\n  NormalizedEntityKeyCompletePart,\n  NormalizedEntityKeyCompletePart\n>;\n\n/**\n * Generate properties for an entity key given the key definition and key values.\n */\nexport function normalizeCompositeKey<E extends Entity>(\n  entity: E | KeyDefinition,\n  key: Partial<CompositeKey>\n): NormalizedEntityCompositeKey {\n  const keyDef = \"partition\" in entity ? entity : entity.key;\n\n  const partitionCompositeKey = formatNormalizedPart(keyDef.partition, (p, i) =>\n    Array.isArray(key) ? key[i] : (key as KeyMap)[p]\n  );\n\n  const sortCompositeKey = keyDef.sort\n    ? formatNormalizedPart(keyDef.sort, (p, i) =>\n        Array.isArray(key)\n          ? key[keyDef.partition.attributes.length + i]\n          : (key as KeyMap)[p]\n      )\n    : undefined;\n\n  return sortCompositeKey\n    ? {\n        partition: partitionCompositeKey,\n        sort: sortCompositeKey,\n      }\n    : {\n        partition: partitionCompositeKey,\n      };\n}\n\nfunction formatNormalizedPart(\n  keyPart: KeyDefinitionPart,\n  valueRetriever: (field: string, index: number) => string | number\n): NormalizedEntityKeyPart {\n  const parts = keyPart.attributes.map((p, i) => ({\n    field: p,\n    value: valueRetriever(p, i),\n  }));\n\n  const missingValueIndex = parts.findIndex((p) => p.value === undefined);\n\n  return {\n    type: keyPart.type,\n    attributes: keyPart.attributes,\n    parts,\n    keyAttribute: keyPart.keyAttribute,\n    keyValue: (keyPart.type === \"number\"\n      ? parts[0]?.value\n      : (missingValueIndex === -1 ? parts : parts.slice(0, missingValueIndex))\n          .map((p) => p.value)\n          .join(\"#\")) as any,\n    partialValue: missingValueIndex !== -1,\n  };\n}\n\nexport function convertNormalizedEntityKeyToMap(\n  key: NormalizedEntityCompositeKey\n): KeyMap<any, any, any> {\n  console.log(\"input key\", JSON.stringify(key));\n  const generatedKey = Object.fromEntries([\n    ...key.partition.parts.map(({ field, value }) => [field, value]),\n    ...(key.sort\n      ? key.sort.parts.map(({ field, value }) => [field, value])\n      : []),\n  ]);\n  console.log(\"generated key\", JSON.stringify(generatedKey));\n  return generatedKey;\n}\n"]} |
@@ -159,2 +159,5 @@ import { assertNever, isAwaitTimerCall, isBucketCall, isBucketCallType, isChildExecutionTarget, isChildWorkflowCall, isConditionCall, isEmitEventsCall, isEntityCall, isEntityOperationOfType, isExpectSignalCall, isInvokeTransactionCall, isRegisterSignalHandlerCall, isSendSignalCall, isTaskCall, WorkflowEventType, } from "@eventual/core/internal"; | ||
} | ||
else if (isEntityOperationOfType("queryIndex", operation)) { | ||
return self.props.entityStore.queryIndex(operation.entityName, operation.indexName, ...operation.params); | ||
} | ||
return self.props.entityStore[operation.operation](operation.entityName, | ||
@@ -299,2 +302,2 @@ // @ts-ignore | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-call-executor.js","sourceRoot":"","sources":["../../src/workflow-call-executor.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ExecutionID, Workflow } from \"@eventual/core\";\nimport {\n  assertNever,\n  AwaitTimerCall,\n  BucketCall,\n  BucketGetObjectSerializedResult,\n  BucketRequest,\n  BucketRequestFailed,\n  BucketRequestSucceeded,\n  ChildWorkflowCall,\n  ChildWorkflowScheduled,\n  EmitEventsCall,\n  EntityCall,\n  EntityOperation,\n  EntityRequest,\n  EntityRequestFailed,\n  EntityRequestSucceeded,\n  EventsEmitted,\n  HistoryStateEvent,\n  InvokeTransactionCall,\n  isAwaitTimerCall,\n  isBucketCall,\n  isBucketCallType,\n  isChildExecutionTarget,\n  isChildWorkflowCall,\n  isConditionCall,\n  isEmitEventsCall,\n  isEntityCall,\n  isEntityOperationOfType,\n  isExpectSignalCall,\n  isInvokeTransactionCall,\n  isRegisterSignalHandlerCall,\n  isSendSignalCall,\n  isTaskCall,\n  SendSignalCall,\n  SignalSent,\n  TaskCall,\n  TaskScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  TransactionRequest,\n  TransactionRequestFailed,\n  TransactionRequestSucceeded,\n  WorkflowEventType,\n} from \"@eventual/core/internal\";\nimport stream from \"stream\";\nimport type { EventClient } from \"./clients/event-client.js\";\nimport type { ExecutionQueueClient } from \"./clients/execution-queue-client.js\";\nimport type { TaskClient, TaskWorkerRequest } from \"./clients/task-client.js\";\nimport type { TimerClient } from \"./clients/timer-client.js\";\nimport type { TransactionClient } from \"./clients/transaction-client.js\";\nimport type { WorkflowClient } from \"./clients/workflow-client.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution.js\";\nimport { normalizeError } from \"./result.js\";\nimport { computeScheduleDate } from \"./schedule.js\";\nimport type { BucketStore } from \"./stores/bucket-store.js\";\nimport type { EntityStore } from \"./stores/entity-store.js\";\nimport { createEvent } from \"./workflow-events.js\";\nimport type { WorkflowCall } from \"./workflow-executor.js\";\n\ninterface WorkflowCallExecutorProps {\n  bucketStore: BucketStore;\n  entityStore: EntityStore;\n  eventClient: EventClient;\n  executionQueueClient: ExecutionQueueClient;\n  taskClient: TaskClient;\n  timerClient: TimerClient;\n  transactionClient: TransactionClient;\n  workflowClient: WorkflowClient;\n}\n\n/**\n * Uses the clients to execute all supported calls and return events.\n */\nexport class WorkflowCallExecutor {\n  constructor(private props: WorkflowCallExecutorProps) {}\n\n  public async executeCall(\n    workflow: Workflow,\n    executionId: ExecutionID,\n    call: WorkflowCall,\n    baseTime: Date\n  ): Promise<HistoryStateEvent | undefined> {\n    if (isTaskCall(call.call)) {\n      return await this.scheduleTask(\n        workflow,\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isChildWorkflowCall(call.call)) {\n      return this.scheduleChildWorkflow(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isAwaitTimerCall(call.call)) {\n      // all timers are computed using the start time of the WorkflowTaskStarted\n      return this.startTimer(executionId, call.call, call.seq, baseTime);\n    } else if (isSendSignalCall(call.call)) {\n      return this.sendSignal(executionId, call.call, call.seq, baseTime);\n    } else if (isEmitEventsCall(call.call)) {\n      return this.emitEvents(call.call, call.seq, baseTime);\n    } else if (\n      isConditionCall(call.call) ||\n      isExpectSignalCall(call.call) ||\n      isRegisterSignalHandlerCall(call.call)\n    ) {\n      // do nothing\n      return undefined;\n    } else if (isEntityCall(call.call)) {\n      return this.executeEntityRequest(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isInvokeTransactionCall(call.call)) {\n      return this.invokeTransaction(executionId, call.call, call.seq, baseTime);\n    } else if (isBucketCall(call.call)) {\n      return this.invokeBucketRequest(\n        call.call,\n        executionId,\n        call.seq,\n        baseTime\n      );\n    } else {\n      return assertNever(call.call, `unknown call type`);\n    }\n  }\n\n  private async scheduleTask(\n    workflow: Workflow,\n    executionId: string,\n    call: TaskCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const request: TaskWorkerRequest = {\n      scheduledTime: baseTime.toISOString(),\n      workflowName: workflow.name,\n      executionId,\n      input: call.input,\n      taskName: call.name,\n      seq,\n      heartbeat: call.heartbeat,\n      retry: 0,\n    };\n\n    await this.props.taskClient.startTask(request);\n\n    return createEvent<TaskScheduled>(\n      {\n        type: WorkflowEventType.TaskScheduled,\n        seq,\n        name: call.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: ExecutionID,\n    call: ChildWorkflowCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startExecution({\n      workflow: call.name,\n      input: call.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, seq),\n      seq,\n      ...call.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>(\n      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq,\n        name: call.name,\n        input: call.input,\n      },\n      baseTime\n    );\n  }\n\n  private async startTimer(\n    executionId: string,\n    call: AwaitTimerCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<TimerScheduled> {\n    // TODO validate\n    await this.props.timerClient.scheduleEvent<TimerCompleted>({\n      event: {\n        type: WorkflowEventType.TimerCompleted,\n        seq,\n      },\n      schedule: call.schedule,\n      executionId,\n    });\n\n    return createEvent<TimerScheduled>(\n      {\n        type: WorkflowEventType.TimerScheduled,\n        seq,\n        untilTime: computeScheduleDate(call.schedule, baseTime).toISOString(),\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    call: SendSignalCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const childExecutionId = isChildExecutionTarget(call.target)\n      ? formatExecutionId(\n          call.target.workflowName,\n          formatChildExecutionName(executionId, call.target.seq)\n        )\n      : call.target.executionId;\n\n    await this.props.executionQueueClient.sendSignal({\n      signal: call.signalId,\n      execution: childExecutionId,\n      id: `${executionId}/${seq}`,\n      payload: call.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq,\n        signalId: call.signalId,\n        payload: call.payload,\n      },\n      baseTime\n    );\n  }\n\n  private async emitEvents(call: EmitEventsCall, seq: number, baseTime: Date) {\n    await this.props.eventClient.emitEvents(...call.events);\n    return createEvent<EventsEmitted>(\n      {\n        type: WorkflowEventType.EventsEmitted,\n        events: call.events,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async executeEntityRequest(\n    executionId: string,\n    call: EntityCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const self = this;\n    try {\n      const result = await invokeEntityOperation(call);\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestSucceeded>(\n          {\n            type: WorkflowEventType.EntityRequestSucceeded,\n            operation: call.operation,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            result,\n            seq,\n          },\n          baseTime\n        )\n      );\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestFailed>(\n          {\n            type: WorkflowEventType.EntityRequestFailed,\n            seq,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            operation: call.operation,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<EntityRequest>(\n      {\n        type: WorkflowEventType.EntityRequest,\n        operation: call,\n        seq,\n      },\n      baseTime\n    );\n\n    async function invokeEntityOperation(operation: EntityOperation) {\n      if (isEntityOperationOfType(\"transact\", operation)) {\n        return self.props.entityStore.transactWrite(operation.items);\n      }\n      return self.props.entityStore[operation.operation](\n        operation.entityName,\n        // @ts-ignore\n        ...operation.params\n      );\n    }\n  }\n\n  private async invokeTransaction(\n    executionId: string,\n    call: InvokeTransactionCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    try {\n      const result = await this.props.transactionClient.executeTransaction({\n        input: call.input,\n        transaction: call.transactionName,\n      });\n      if (result.succeeded) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestSucceeded>(\n            {\n              type: WorkflowEventType.TransactionRequestSucceeded,\n              result: result.output,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestFailed>(\n            {\n              type: WorkflowEventType.TransactionRequestFailed,\n              error: \"Transaction Failed\",\n              message: \"\",\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<TransactionRequestFailed>(\n          {\n            type: WorkflowEventType.TransactionRequestFailed,\n            ...normalizeError(err),\n            seq,\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<TransactionRequest>(\n      {\n        type: WorkflowEventType.TransactionRequest,\n        input: call.input,\n        transactionName: call.transactionName,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async invokeBucketRequest(\n    call: BucketCall,\n    executionId: string,\n    seq: number,\n    baseTime: Date\n  ) {\n    if (isBucketCallType(\"put\", call)) {\n      // handle put separately to serialize the input\n      const [key, data] = call.params;\n\n      const buffer =\n        typeof data === \"string\" || data instanceof Buffer\n          ? data\n          : await streamToBuffer(data);\n\n      try {\n        const result = await this.props.bucketStore.put(\n          call.bucketName,\n          key,\n          buffer\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: \"put\",\n              result: {\n                etag: result.etag,\n              },\n              seq,\n            },\n            baseTime\n          )\n        );\n      } catch (err) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestFailed>(\n            {\n              type: WorkflowEventType.BucketRequestFailed,\n              operation: \"put\",\n              seq,\n              ...normalizeError(err),\n            },\n            baseTime\n          )\n        );\n      }\n\n      return createEvent<BucketRequest>(\n        {\n          type: WorkflowEventType.BucketRequest,\n          operation: {\n            operation: \"put\",\n            bucketName: call.bucketName,\n            key,\n            // serialize the data put into a string to be stored\n            data:\n              typeof buffer === \"string\" ? buffer : buffer.toString(\"base64\"),\n            isBase64Encoded: typeof buffer !== \"string\",\n          },\n          seq,\n        },\n        baseTime\n      );\n    }\n\n    try {\n      // handle get separately to serialize the result\n      if (isBucketCallType(\"get\", call)) {\n        const result = await this.props.bucketStore.get(\n          call.bucketName,\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result: result\n                ? ({\n                    // serialize the data retrieved data to be stored\n                    body: (\n                      await streamToBuffer(result.body)\n                    ).toString(\"base64\"),\n                    base64Encoded: true,\n                    contentLength: result.contentLength,\n                    etag: result.etag,\n                  } satisfies BucketGetObjectSerializedResult)\n                : undefined,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        const result = await this.props.bucketStore[call.operation](\n          call.bucketName,\n          // @ts-ignore\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result,\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<BucketRequestFailed>(\n          {\n            type: WorkflowEventType.BucketRequestFailed,\n            operation: call.operation,\n            seq,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<BucketRequest>(\n      {\n        type: WorkflowEventType.BucketRequest,\n        operation: {\n          operation: call.operation,\n          bucketName: call.bucketName,\n          // @ts-ignore\n          params: call.params,\n        },\n        seq,\n      },\n      baseTime\n    );\n  }\n}\n\nasync function streamToBuffer(stream: stream.Readable) {\n  // lets have a ReadableStream as a stream variable\n  const chunks = [];\n\n  for await (const chunk of stream) {\n    chunks.push(Buffer.from(chunk));\n  }\n\n  return Buffer.concat(chunks);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-call-executor.js","sourceRoot":"","sources":["../../src/workflow-call-executor.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ExecutionID, Workflow } from \"@eventual/core\";\nimport {\n  assertNever,\n  AwaitTimerCall,\n  BucketCall,\n  BucketGetObjectSerializedResult,\n  BucketRequest,\n  BucketRequestFailed,\n  BucketRequestSucceeded,\n  ChildWorkflowCall,\n  ChildWorkflowScheduled,\n  EmitEventsCall,\n  EntityCall,\n  EntityOperation,\n  EntityRequest,\n  EntityRequestFailed,\n  EntityRequestSucceeded,\n  EventsEmitted,\n  HistoryStateEvent,\n  InvokeTransactionCall,\n  isAwaitTimerCall,\n  isBucketCall,\n  isBucketCallType,\n  isChildExecutionTarget,\n  isChildWorkflowCall,\n  isConditionCall,\n  isEmitEventsCall,\n  isEntityCall,\n  isEntityOperationOfType,\n  isExpectSignalCall,\n  isInvokeTransactionCall,\n  isRegisterSignalHandlerCall,\n  isSendSignalCall,\n  isTaskCall,\n  SendSignalCall,\n  SignalSent,\n  TaskCall,\n  TaskScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  TransactionRequest,\n  TransactionRequestFailed,\n  TransactionRequestSucceeded,\n  WorkflowEventType,\n} from \"@eventual/core/internal\";\nimport stream from \"stream\";\nimport type { EventClient } from \"./clients/event-client.js\";\nimport type { ExecutionQueueClient } from \"./clients/execution-queue-client.js\";\nimport type { TaskClient, TaskWorkerRequest } from \"./clients/task-client.js\";\nimport type { TimerClient } from \"./clients/timer-client.js\";\nimport type { TransactionClient } from \"./clients/transaction-client.js\";\nimport type { WorkflowClient } from \"./clients/workflow-client.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution.js\";\nimport { normalizeError } from \"./result.js\";\nimport { computeScheduleDate } from \"./schedule.js\";\nimport type { BucketStore } from \"./stores/bucket-store.js\";\nimport type { EntityStore } from \"./stores/entity-store.js\";\nimport { createEvent } from \"./workflow-events.js\";\nimport type { WorkflowCall } from \"./workflow-executor.js\";\n\ninterface WorkflowCallExecutorProps {\n  bucketStore: BucketStore;\n  entityStore: EntityStore;\n  eventClient: EventClient;\n  executionQueueClient: ExecutionQueueClient;\n  taskClient: TaskClient;\n  timerClient: TimerClient;\n  transactionClient: TransactionClient;\n  workflowClient: WorkflowClient;\n}\n\n/**\n * Uses the clients to execute all supported calls and return events.\n */\nexport class WorkflowCallExecutor {\n  constructor(private props: WorkflowCallExecutorProps) {}\n\n  public async executeCall(\n    workflow: Workflow,\n    executionId: ExecutionID,\n    call: WorkflowCall,\n    baseTime: Date\n  ): Promise<HistoryStateEvent | undefined> {\n    if (isTaskCall(call.call)) {\n      return await this.scheduleTask(\n        workflow,\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isChildWorkflowCall(call.call)) {\n      return this.scheduleChildWorkflow(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isAwaitTimerCall(call.call)) {\n      // all timers are computed using the start time of the WorkflowTaskStarted\n      return this.startTimer(executionId, call.call, call.seq, baseTime);\n    } else if (isSendSignalCall(call.call)) {\n      return this.sendSignal(executionId, call.call, call.seq, baseTime);\n    } else if (isEmitEventsCall(call.call)) {\n      return this.emitEvents(call.call, call.seq, baseTime);\n    } else if (\n      isConditionCall(call.call) ||\n      isExpectSignalCall(call.call) ||\n      isRegisterSignalHandlerCall(call.call)\n    ) {\n      // do nothing\n      return undefined;\n    } else if (isEntityCall(call.call)) {\n      return this.executeEntityRequest(\n        executionId,\n        call.call,\n        call.seq,\n        baseTime\n      );\n    } else if (isInvokeTransactionCall(call.call)) {\n      return this.invokeTransaction(executionId, call.call, call.seq, baseTime);\n    } else if (isBucketCall(call.call)) {\n      return this.invokeBucketRequest(\n        call.call,\n        executionId,\n        call.seq,\n        baseTime\n      );\n    } else {\n      return assertNever(call.call, `unknown call type`);\n    }\n  }\n\n  private async scheduleTask(\n    workflow: Workflow,\n    executionId: string,\n    call: TaskCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const request: TaskWorkerRequest = {\n      scheduledTime: baseTime.toISOString(),\n      workflowName: workflow.name,\n      executionId,\n      input: call.input,\n      taskName: call.name,\n      seq,\n      heartbeat: call.heartbeat,\n      retry: 0,\n    };\n\n    await this.props.taskClient.startTask(request);\n\n    return createEvent<TaskScheduled>(\n      {\n        type: WorkflowEventType.TaskScheduled,\n        seq,\n        name: call.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: ExecutionID,\n    call: ChildWorkflowCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startExecution({\n      workflow: call.name,\n      input: call.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, seq),\n      seq,\n      ...call.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>(\n      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq,\n        name: call.name,\n        input: call.input,\n      },\n      baseTime\n    );\n  }\n\n  private async startTimer(\n    executionId: string,\n    call: AwaitTimerCall,\n    seq: number,\n    baseTime: Date\n  ): Promise<TimerScheduled> {\n    // TODO validate\n    await this.props.timerClient.scheduleEvent<TimerCompleted>({\n      event: {\n        type: WorkflowEventType.TimerCompleted,\n        seq,\n      },\n      schedule: call.schedule,\n      executionId,\n    });\n\n    return createEvent<TimerScheduled>(\n      {\n        type: WorkflowEventType.TimerScheduled,\n        seq,\n        untilTime: computeScheduleDate(call.schedule, baseTime).toISOString(),\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    call: SendSignalCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const childExecutionId = isChildExecutionTarget(call.target)\n      ? formatExecutionId(\n          call.target.workflowName,\n          formatChildExecutionName(executionId, call.target.seq)\n        )\n      : call.target.executionId;\n\n    await this.props.executionQueueClient.sendSignal({\n      signal: call.signalId,\n      execution: childExecutionId,\n      id: `${executionId}/${seq}`,\n      payload: call.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq,\n        signalId: call.signalId,\n        payload: call.payload,\n      },\n      baseTime\n    );\n  }\n\n  private async emitEvents(call: EmitEventsCall, seq: number, baseTime: Date) {\n    await this.props.eventClient.emitEvents(...call.events);\n    return createEvent<EventsEmitted>(\n      {\n        type: WorkflowEventType.EventsEmitted,\n        events: call.events,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async executeEntityRequest(\n    executionId: string,\n    call: EntityCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    const self = this;\n    try {\n      const result = await invokeEntityOperation(call);\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestSucceeded>(\n          {\n            type: WorkflowEventType.EntityRequestSucceeded,\n            operation: call.operation,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            result,\n            seq,\n          },\n          baseTime\n        )\n      );\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<EntityRequestFailed>(\n          {\n            type: WorkflowEventType.EntityRequestFailed,\n            seq,\n            name: isEntityOperationOfType(\"transact\", call)\n              ? undefined\n              : call.entityName,\n            operation: call.operation,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<EntityRequest>(\n      {\n        type: WorkflowEventType.EntityRequest,\n        operation: call,\n        seq,\n      },\n      baseTime\n    );\n\n    async function invokeEntityOperation(operation: EntityOperation) {\n      if (isEntityOperationOfType(\"transact\", operation)) {\n        return self.props.entityStore.transactWrite(operation.items);\n      } else if (isEntityOperationOfType(\"queryIndex\", operation)) {\n        return self.props.entityStore.queryIndex(\n          operation.entityName,\n          operation.indexName,\n          ...operation.params\n        );\n      }\n      return self.props.entityStore[operation.operation](\n        operation.entityName,\n        // @ts-ignore\n        ...operation.params\n      );\n    }\n  }\n\n  private async invokeTransaction(\n    executionId: string,\n    call: InvokeTransactionCall,\n    seq: number,\n    baseTime: Date\n  ) {\n    try {\n      const result = await this.props.transactionClient.executeTransaction({\n        input: call.input,\n        transaction: call.transactionName,\n      });\n      if (result.succeeded) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestSucceeded>(\n            {\n              type: WorkflowEventType.TransactionRequestSucceeded,\n              result: result.output,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<TransactionRequestFailed>(\n            {\n              type: WorkflowEventType.TransactionRequestFailed,\n              error: \"Transaction Failed\",\n              message: \"\",\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<TransactionRequestFailed>(\n          {\n            type: WorkflowEventType.TransactionRequestFailed,\n            ...normalizeError(err),\n            seq,\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<TransactionRequest>(\n      {\n        type: WorkflowEventType.TransactionRequest,\n        input: call.input,\n        transactionName: call.transactionName,\n        seq,\n      },\n      baseTime\n    );\n  }\n\n  private async invokeBucketRequest(\n    call: BucketCall,\n    executionId: string,\n    seq: number,\n    baseTime: Date\n  ) {\n    if (isBucketCallType(\"put\", call)) {\n      // handle put separately to serialize the input\n      const [key, data] = call.params;\n\n      const buffer =\n        typeof data === \"string\" || data instanceof Buffer\n          ? data\n          : await streamToBuffer(data);\n\n      try {\n        const result = await this.props.bucketStore.put(\n          call.bucketName,\n          key,\n          buffer\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: \"put\",\n              result: {\n                etag: result.etag,\n              },\n              seq,\n            },\n            baseTime\n          )\n        );\n      } catch (err) {\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestFailed>(\n            {\n              type: WorkflowEventType.BucketRequestFailed,\n              operation: \"put\",\n              seq,\n              ...normalizeError(err),\n            },\n            baseTime\n          )\n        );\n      }\n\n      return createEvent<BucketRequest>(\n        {\n          type: WorkflowEventType.BucketRequest,\n          operation: {\n            operation: \"put\",\n            bucketName: call.bucketName,\n            key,\n            // serialize the data put into a string to be stored\n            data:\n              typeof buffer === \"string\" ? buffer : buffer.toString(\"base64\"),\n            isBase64Encoded: typeof buffer !== \"string\",\n          },\n          seq,\n        },\n        baseTime\n      );\n    }\n\n    try {\n      // handle get separately to serialize the result\n      if (isBucketCallType(\"get\", call)) {\n        const result = await this.props.bucketStore.get(\n          call.bucketName,\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result: result\n                ? ({\n                    // serialize the data retrieved data to be stored\n                    body: (\n                      await streamToBuffer(result.body)\n                    ).toString(\"base64\"),\n                    base64Encoded: true,\n                    contentLength: result.contentLength,\n                    etag: result.etag,\n                  } satisfies BucketGetObjectSerializedResult)\n                : undefined,\n              seq,\n            },\n            baseTime\n          )\n        );\n      } else {\n        const result = await this.props.bucketStore[call.operation](\n          call.bucketName,\n          // @ts-ignore\n          ...call.params\n        );\n\n        await this.props.executionQueueClient.submitExecutionEvents(\n          executionId,\n          createEvent<BucketRequestSucceeded>(\n            {\n              type: WorkflowEventType.BucketRequestSucceeded,\n              operation: call.operation,\n              result,\n              seq,\n            },\n            baseTime\n          )\n        );\n      }\n    } catch (err) {\n      await this.props.executionQueueClient.submitExecutionEvents(\n        executionId,\n        createEvent<BucketRequestFailed>(\n          {\n            type: WorkflowEventType.BucketRequestFailed,\n            operation: call.operation,\n            seq,\n            ...normalizeError(err),\n          },\n          baseTime\n        )\n      );\n    }\n\n    return createEvent<BucketRequest>(\n      {\n        type: WorkflowEventType.BucketRequest,\n        operation: {\n          operation: call.operation,\n          bucketName: call.bucketName,\n          // @ts-ignore\n          params: call.params,\n        },\n        seq,\n      },\n      baseTime\n    );\n  }\n}\n\nasync function streamToBuffer(stream: stream.Readable) {\n  // lets have a ReadableStream as a stream variable\n  const chunks = [];\n\n  for await (const chunk of stream) {\n    chunks.push(Buffer.from(chunk));\n  }\n\n  return Buffer.concat(chunks);\n}\n"]} |
{ | ||
"name": "@eventual/core-runtime", | ||
"version": "0.37.3", | ||
"version": "0.38.0", | ||
"exports": { | ||
@@ -20,3 +20,3 @@ ".": { | ||
"zod": "^3.21.4", | ||
"@eventual/core": "^0.37.3" | ||
"@eventual/core": "^0.38.0" | ||
}, | ||
@@ -28,3 +28,3 @@ "devDependencies": { | ||
"jest": "^29", | ||
"ts-jest": "^29", | ||
"ts-jest": "^29.1.0", | ||
"ts-node": "^10.9.1", | ||
@@ -31,0 +31,0 @@ "typescript": "^5" |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
2052792
14365
+ Added@eventual/core@0.38.0(transitive)
- Removed@eventual/core@0.37.3(transitive)
Updated@eventual/core@^0.38.0