@hotmeshio/hotmesh 0.0.8 → 0.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +4 -7
- package/README.md +82 -85
- package/build/{cjs/modules → modules}/key.d.ts +2 -2
- package/build/{cjs/modules → modules}/key.js +3 -3
- package/build/{esm/package.json → package.json} +4 -11
- package/build/{cjs/services → services}/durable/native.js +2 -3
- package/build/{esm/services → services}/durable/worker.d.ts +1 -3
- package/build/{cjs/services → services}/durable/worker.js +9 -33
- package/build/{cjs/services → services}/durable/workflow.js +6 -1
- package/build/{cjs/services → services}/hotmesh/index.js +1 -1
- package/build/{cjs/services → services}/store/index.js +2 -2
- package/build/{cjs/services → services}/stream/clients/ioredis.js +1 -1
- package/build/{cjs/services → services}/stream/clients/redis.js +1 -1
- package/build/{cjs/services → services}/sub/clients/ioredis.js +1 -1
- package/build/{cjs/services → services}/sub/clients/redis.js +1 -1
- package/build/{cjs/types → types}/durable.d.ts +5 -7
- package/modules/key.ts +2 -2
- package/package.json +4 -11
- package/services/durable/native.ts +2 -3
- package/services/durable/worker.ts +9 -10
- package/services/durable/workflow.ts +7 -1
- package/services/hotmesh/index.ts +2 -2
- package/services/store/index.ts +3 -3
- package/services/stream/clients/ioredis.ts +2 -2
- package/services/stream/clients/redis.ts +2 -2
- package/services/sub/clients/ioredis.ts +2 -2
- package/services/sub/clients/redis.ts +2 -2
- package/types/durable.ts +5 -5
- package/build/cjs/package.json +0 -82
- package/build/cjs/services/durable/worker.d.ts +0 -38
- package/build/esm/index.d.ts +0 -4
- package/build/esm/index.js +0 -3
- package/build/esm/modules/errors.d.ts +0 -28
- package/build/esm/modules/errors.js +0 -41
- package/build/esm/modules/key.d.ts +0 -75
- package/build/esm/modules/key.js +0 -111
- package/build/esm/modules/utils.d.ts +0 -34
- package/build/esm/modules/utils.js +0 -154
- package/build/esm/services/activities/activity.d.ts +0 -67
- package/build/esm/services/activities/activity.js +0 -486
- package/build/esm/services/activities/await.d.ts +0 -16
- package/build/esm/services/activities/await.js +0 -140
- package/build/esm/services/activities/cycle.d.ts +0 -19
- package/build/esm/services/activities/cycle.js +0 -74
- package/build/esm/services/activities/emit.d.ts +0 -9
- package/build/esm/services/activities/emit.js +0 -10
- package/build/esm/services/activities/index.d.ts +0 -17
- package/build/esm/services/activities/index.js +0 -16
- package/build/esm/services/activities/iterate.d.ts +0 -9
- package/build/esm/services/activities/iterate.js +0 -10
- package/build/esm/services/activities/trigger.d.ts +0 -22
- package/build/esm/services/activities/trigger.js +0 -158
- package/build/esm/services/activities/worker.d.ts +0 -11
- package/build/esm/services/activities/worker.js +0 -70
- package/build/esm/services/collator/index.d.ts +0 -73
- package/build/esm/services/collator/index.js +0 -221
- package/build/esm/services/compiler/deployer.d.ts +0 -36
- package/build/esm/services/compiler/deployer.js +0 -423
- package/build/esm/services/compiler/index.d.ts +0 -30
- package/build/esm/services/compiler/index.js +0 -82
- package/build/esm/services/compiler/validator.d.ts +0 -32
- package/build/esm/services/compiler/validator.js +0 -131
- package/build/esm/services/connector/clients/ioredis.d.ts +0 -13
- package/build/esm/services/connector/clients/ioredis.js +0 -47
- package/build/esm/services/connector/clients/redis.d.ts +0 -13
- package/build/esm/services/connector/clients/redis.js +0 -59
- package/build/esm/services/connector/index.d.ts +0 -5
- package/build/esm/services/connector/index.js +0 -27
- package/build/esm/services/dimension/index.d.ts +0 -29
- package/build/esm/services/dimension/index.js +0 -32
- package/build/esm/services/durable/asyncLocalStorage.d.ts +0 -3
- package/build/esm/services/durable/asyncLocalStorage.js +0 -2
- package/build/esm/services/durable/client.d.ts +0 -15
- package/build/esm/services/durable/client.js +0 -114
- package/build/esm/services/durable/connection.d.ts +0 -4
- package/build/esm/services/durable/connection.js +0 -47
- package/build/esm/services/durable/factory.d.ts +0 -3
- package/build/esm/services/durable/factory.js +0 -135
- package/build/esm/services/durable/handle.d.ts +0 -8
- package/build/esm/services/durable/handle.js +0 -34
- package/build/esm/services/durable/index.d.ts +0 -57
- package/build/esm/services/durable/index.js +0 -55
- package/build/esm/services/durable/native.d.ts +0 -4
- package/build/esm/services/durable/native.js +0 -43
- package/build/esm/services/durable/worker.js +0 -267
- package/build/esm/services/durable/workflow.d.ts +0 -6
- package/build/esm/services/durable/workflow.js +0 -132
- package/build/esm/services/engine/index.d.ts +0 -82
- package/build/esm/services/engine/index.js +0 -522
- package/build/esm/services/hotmesh/index.d.ts +0 -45
- package/build/esm/services/hotmesh/index.js +0 -131
- package/build/esm/services/logger/index.d.ts +0 -17
- package/build/esm/services/logger/index.js +0 -70
- package/build/esm/services/mapper/index.d.ts +0 -24
- package/build/esm/services/mapper/index.js +0 -72
- package/build/esm/services/pipe/functions/array.d.ts +0 -24
- package/build/esm/services/pipe/functions/array.js +0 -66
- package/build/esm/services/pipe/functions/bitwise.d.ts +0 -9
- package/build/esm/services/pipe/functions/bitwise.js +0 -21
- package/build/esm/services/pipe/functions/conditional.d.ts +0 -10
- package/build/esm/services/pipe/functions/conditional.js +0 -24
- package/build/esm/services/pipe/functions/date.d.ts +0 -57
- package/build/esm/services/pipe/functions/date.js +0 -164
- package/build/esm/services/pipe/functions/index.d.ts +0 -25
- package/build/esm/services/pipe/functions/index.js +0 -24
- package/build/esm/services/pipe/functions/json.d.ts +0 -5
- package/build/esm/services/pipe/functions/json.js +0 -9
- package/build/esm/services/pipe/functions/math.d.ts +0 -38
- package/build/esm/services/pipe/functions/math.js +0 -108
- package/build/esm/services/pipe/functions/number.d.ts +0 -25
- package/build/esm/services/pipe/functions/number.js +0 -130
- package/build/esm/services/pipe/functions/object.d.ts +0 -22
- package/build/esm/services/pipe/functions/object.js +0 -60
- package/build/esm/services/pipe/functions/string.d.ts +0 -23
- package/build/esm/services/pipe/functions/string.js +0 -66
- package/build/esm/services/pipe/functions/symbol.d.ts +0 -12
- package/build/esm/services/pipe/functions/symbol.js +0 -30
- package/build/esm/services/pipe/functions/unary.d.ts +0 -7
- package/build/esm/services/pipe/functions/unary.js +0 -15
- package/build/esm/services/pipe/index.d.ts +0 -30
- package/build/esm/services/pipe/index.js +0 -122
- package/build/esm/services/quorum/index.d.ts +0 -34
- package/build/esm/services/quorum/index.js +0 -144
- package/build/esm/services/reporter/index.d.ts +0 -47
- package/build/esm/services/reporter/index.js +0 -327
- package/build/esm/services/serializer/index.d.ts +0 -41
- package/build/esm/services/serializer/index.js +0 -251
- package/build/esm/services/signaler/store.d.ts +0 -15
- package/build/esm/services/signaler/store.js +0 -50
- package/build/esm/services/signaler/stream.d.ts +0 -43
- package/build/esm/services/signaler/stream.js +0 -314
- package/build/esm/services/store/cache.d.ts +0 -66
- package/build/esm/services/store/cache.js +0 -124
- package/build/esm/services/store/clients/ioredis.d.ts +0 -27
- package/build/esm/services/store/clients/ioredis.js +0 -93
- package/build/esm/services/store/clients/redis.d.ts +0 -29
- package/build/esm/services/store/clients/redis.js +0 -140
- package/build/esm/services/store/index.d.ts +0 -88
- package/build/esm/services/store/index.js +0 -623
- package/build/esm/services/stream/clients/ioredis.d.ts +0 -23
- package/build/esm/services/stream/clients/ioredis.js +0 -112
- package/build/esm/services/stream/clients/redis.d.ts +0 -23
- package/build/esm/services/stream/clients/redis.js +0 -116
- package/build/esm/services/stream/index.d.ts +0 -21
- package/build/esm/services/stream/index.js +0 -6
- package/build/esm/services/sub/clients/ioredis.d.ts +0 -20
- package/build/esm/services/sub/clients/ioredis.js +0 -69
- package/build/esm/services/sub/clients/redis.d.ts +0 -20
- package/build/esm/services/sub/clients/redis.js +0 -60
- package/build/esm/services/sub/index.d.ts +0 -18
- package/build/esm/services/sub/index.js +0 -6
- package/build/esm/services/task/index.d.ts +0 -18
- package/build/esm/services/task/index.js +0 -70
- package/build/esm/services/telemetry/index.d.ts +0 -49
- package/build/esm/services/telemetry/index.js +0 -217
- package/build/esm/services/worker/index.d.ts +0 -30
- package/build/esm/services/worker/index.js +0 -102
- package/build/esm/types/activity.d.ts +0 -92
- package/build/esm/types/activity.js +0 -1
- package/build/esm/types/app.d.ts +0 -16
- package/build/esm/types/app.js +0 -1
- package/build/esm/types/async.d.ts +0 -5
- package/build/esm/types/async.js +0 -1
- package/build/esm/types/cache.d.ts +0 -1
- package/build/esm/types/cache.js +0 -1
- package/build/esm/types/collator.d.ts +0 -8
- package/build/esm/types/collator.js +0 -8
- package/build/esm/types/durable.d.ts +0 -59
- package/build/esm/types/durable.js +0 -1
- package/build/esm/types/hook.d.ts +0 -31
- package/build/esm/types/hook.js +0 -6
- package/build/esm/types/hotmesh.d.ts +0 -82
- package/build/esm/types/hotmesh.js +0 -1
- package/build/esm/types/index.d.ts +0 -20
- package/build/esm/types/index.js +0 -5
- package/build/esm/types/ioredisclient.d.ts +0 -5
- package/build/esm/types/ioredisclient.js +0 -2
- package/build/esm/types/job.d.ts +0 -50
- package/build/esm/types/job.js +0 -1
- package/build/esm/types/logger.d.ts +0 -6
- package/build/esm/types/logger.js +0 -1
- package/build/esm/types/map.d.ts +0 -4
- package/build/esm/types/map.js +0 -1
- package/build/esm/types/pipe.d.ts +0 -4
- package/build/esm/types/pipe.js +0 -1
- package/build/esm/types/quorum.d.ts +0 -46
- package/build/esm/types/quorum.js +0 -1
- package/build/esm/types/redis.d.ts +0 -8
- package/build/esm/types/redis.js +0 -1
- package/build/esm/types/redisclient.d.ts +0 -25
- package/build/esm/types/redisclient.js +0 -1
- package/build/esm/types/serializer.d.ts +0 -33
- package/build/esm/types/serializer.js +0 -1
- package/build/esm/types/stats.d.ts +0 -83
- package/build/esm/types/stats.js +0 -1
- package/build/esm/types/stream.d.ts +0 -67
- package/build/esm/types/stream.js +0 -22
- package/build/esm/types/telemetry.d.ts +0 -1
- package/build/esm/types/telemetry.js +0 -1
- package/build/esm/types/transition.d.ts +0 -17
- package/build/esm/types/transition.js +0 -1
- package/tsconfig.cjs.json +0 -8
- package/tsconfig.esm.json +0 -9
- /package/build/{cjs/index.d.ts → index.d.ts} +0 -0
- /package/build/{cjs/index.js → index.js} +0 -0
- /package/build/{cjs/modules → modules}/errors.d.ts +0 -0
- /package/build/{cjs/modules → modules}/errors.js +0 -0
- /package/build/{cjs/modules → modules}/utils.d.ts +0 -0
- /package/build/{cjs/modules → modules}/utils.js +0 -0
- /package/build/{cjs/services → services}/activities/activity.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/activity.js +0 -0
- /package/build/{cjs/services → services}/activities/await.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/await.js +0 -0
- /package/build/{cjs/services → services}/activities/cycle.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/cycle.js +0 -0
- /package/build/{cjs/services → services}/activities/emit.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/emit.js +0 -0
- /package/build/{cjs/services → services}/activities/index.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/index.js +0 -0
- /package/build/{cjs/services → services}/activities/iterate.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/iterate.js +0 -0
- /package/build/{cjs/services → services}/activities/trigger.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/trigger.js +0 -0
- /package/build/{cjs/services → services}/activities/worker.d.ts +0 -0
- /package/build/{cjs/services → services}/activities/worker.js +0 -0
- /package/build/{cjs/services → services}/collator/index.d.ts +0 -0
- /package/build/{cjs/services → services}/collator/index.js +0 -0
- /package/build/{cjs/services → services}/compiler/deployer.d.ts +0 -0
- /package/build/{cjs/services → services}/compiler/deployer.js +0 -0
- /package/build/{cjs/services → services}/compiler/index.d.ts +0 -0
- /package/build/{cjs/services → services}/compiler/index.js +0 -0
- /package/build/{cjs/services → services}/compiler/validator.d.ts +0 -0
- /package/build/{cjs/services → services}/compiler/validator.js +0 -0
- /package/build/{cjs/services → services}/connector/clients/ioredis.d.ts +0 -0
- /package/build/{cjs/services → services}/connector/clients/ioredis.js +0 -0
- /package/build/{cjs/services → services}/connector/clients/redis.d.ts +0 -0
- /package/build/{cjs/services → services}/connector/clients/redis.js +0 -0
- /package/build/{cjs/services → services}/connector/index.d.ts +0 -0
- /package/build/{cjs/services → services}/connector/index.js +0 -0
- /package/build/{cjs/services → services}/dimension/index.d.ts +0 -0
- /package/build/{cjs/services → services}/dimension/index.js +0 -0
- /package/build/{cjs/services → services}/durable/asyncLocalStorage.d.ts +0 -0
- /package/build/{cjs/services → services}/durable/asyncLocalStorage.js +0 -0
- /package/build/{cjs/services → services}/durable/client.d.ts +0 -0
- /package/build/{cjs/services → services}/durable/client.js +0 -0
- /package/build/{cjs/services → services}/durable/connection.d.ts +0 -0
- /package/build/{cjs/services → services}/durable/connection.js +0 -0
- /package/build/{cjs/services → services}/durable/factory.d.ts +0 -0
- /package/build/{cjs/services → services}/durable/factory.js +0 -0
- /package/build/{cjs/services → services}/durable/handle.d.ts +0 -0
- /package/build/{cjs/services → services}/durable/handle.js +0 -0
- /package/build/{cjs/services → services}/durable/index.d.ts +0 -0
- /package/build/{cjs/services → services}/durable/index.js +0 -0
- /package/build/{cjs/services → services}/durable/native.d.ts +0 -0
- /package/build/{cjs/services → services}/durable/workflow.d.ts +0 -0
- /package/build/{cjs/services → services}/engine/index.d.ts +0 -0
- /package/build/{cjs/services → services}/engine/index.js +0 -0
- /package/build/{cjs/services → services}/hotmesh/index.d.ts +0 -0
- /package/build/{cjs/services → services}/logger/index.d.ts +0 -0
- /package/build/{cjs/services → services}/logger/index.js +0 -0
- /package/build/{cjs/services → services}/mapper/index.d.ts +0 -0
- /package/build/{cjs/services → services}/mapper/index.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/array.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/array.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/bitwise.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/bitwise.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/conditional.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/conditional.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/date.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/date.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/index.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/index.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/json.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/json.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/math.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/math.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/number.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/number.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/object.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/object.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/string.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/string.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/symbol.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/symbol.js +0 -0
- /package/build/{cjs/services → services}/pipe/functions/unary.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/functions/unary.js +0 -0
- /package/build/{cjs/services → services}/pipe/index.d.ts +0 -0
- /package/build/{cjs/services → services}/pipe/index.js +0 -0
- /package/build/{cjs/services → services}/quorum/index.d.ts +0 -0
- /package/build/{cjs/services → services}/quorum/index.js +0 -0
- /package/build/{cjs/services → services}/reporter/index.d.ts +0 -0
- /package/build/{cjs/services → services}/reporter/index.js +0 -0
- /package/build/{cjs/services → services}/serializer/index.d.ts +0 -0
- /package/build/{cjs/services → services}/serializer/index.js +0 -0
- /package/build/{cjs/services → services}/signaler/store.d.ts +0 -0
- /package/build/{cjs/services → services}/signaler/store.js +0 -0
- /package/build/{cjs/services → services}/signaler/stream.d.ts +0 -0
- /package/build/{cjs/services → services}/signaler/stream.js +0 -0
- /package/build/{cjs/services → services}/store/cache.d.ts +0 -0
- /package/build/{cjs/services → services}/store/cache.js +0 -0
- /package/build/{cjs/services → services}/store/clients/ioredis.d.ts +0 -0
- /package/build/{cjs/services → services}/store/clients/ioredis.js +0 -0
- /package/build/{cjs/services → services}/store/clients/redis.d.ts +0 -0
- /package/build/{cjs/services → services}/store/clients/redis.js +0 -0
- /package/build/{cjs/services → services}/store/index.d.ts +0 -0
- /package/build/{cjs/services → services}/stream/clients/ioredis.d.ts +0 -0
- /package/build/{cjs/services → services}/stream/clients/redis.d.ts +0 -0
- /package/build/{cjs/services → services}/stream/index.d.ts +0 -0
- /package/build/{cjs/services → services}/stream/index.js +0 -0
- /package/build/{cjs/services → services}/sub/clients/ioredis.d.ts +0 -0
- /package/build/{cjs/services → services}/sub/clients/redis.d.ts +0 -0
- /package/build/{cjs/services → services}/sub/index.d.ts +0 -0
- /package/build/{cjs/services → services}/sub/index.js +0 -0
- /package/build/{cjs/services → services}/task/index.d.ts +0 -0
- /package/build/{cjs/services → services}/task/index.js +0 -0
- /package/build/{cjs/services → services}/telemetry/index.d.ts +0 -0
- /package/build/{cjs/services → services}/telemetry/index.js +0 -0
- /package/build/{cjs/services → services}/worker/index.d.ts +0 -0
- /package/build/{cjs/services → services}/worker/index.js +0 -0
- /package/build/{cjs/types → types}/activity.d.ts +0 -0
- /package/build/{cjs/types → types}/activity.js +0 -0
- /package/build/{cjs/types → types}/app.d.ts +0 -0
- /package/build/{cjs/types → types}/app.js +0 -0
- /package/build/{cjs/types → types}/async.d.ts +0 -0
- /package/build/{cjs/types → types}/async.js +0 -0
- /package/build/{cjs/types → types}/cache.d.ts +0 -0
- /package/build/{cjs/types → types}/cache.js +0 -0
- /package/build/{cjs/types → types}/collator.d.ts +0 -0
- /package/build/{cjs/types → types}/collator.js +0 -0
- /package/build/{cjs/types → types}/durable.js +0 -0
- /package/build/{cjs/types → types}/hook.d.ts +0 -0
- /package/build/{cjs/types → types}/hook.js +0 -0
- /package/build/{cjs/types → types}/hotmesh.d.ts +0 -0
- /package/build/{cjs/types → types}/hotmesh.js +0 -0
- /package/build/{cjs/types → types}/index.d.ts +0 -0
- /package/build/{cjs/types → types}/index.js +0 -0
- /package/build/{cjs/types → types}/ioredisclient.d.ts +0 -0
- /package/build/{cjs/types → types}/ioredisclient.js +0 -0
- /package/build/{cjs/types → types}/job.d.ts +0 -0
- /package/build/{cjs/types → types}/job.js +0 -0
- /package/build/{cjs/types → types}/logger.d.ts +0 -0
- /package/build/{cjs/types → types}/logger.js +0 -0
- /package/build/{cjs/types → types}/map.d.ts +0 -0
- /package/build/{cjs/types → types}/map.js +0 -0
- /package/build/{cjs/types → types}/pipe.d.ts +0 -0
- /package/build/{cjs/types → types}/pipe.js +0 -0
- /package/build/{cjs/types → types}/quorum.d.ts +0 -0
- /package/build/{cjs/types → types}/quorum.js +0 -0
- /package/build/{cjs/types → types}/redis.d.ts +0 -0
- /package/build/{cjs/types → types}/redis.js +0 -0
- /package/build/{cjs/types → types}/redisclient.d.ts +0 -0
- /package/build/{cjs/types → types}/redisclient.js +0 -0
- /package/build/{cjs/types → types}/serializer.d.ts +0 -0
- /package/build/{cjs/types → types}/serializer.js +0 -0
- /package/build/{cjs/types → types}/stats.d.ts +0 -0
- /package/build/{cjs/types → types}/stats.js +0 -0
- /package/build/{cjs/types → types}/stream.d.ts +0 -0
- /package/build/{cjs/types → types}/stream.js +0 -0
- /package/build/{cjs/types → types}/telemetry.d.ts +0 -0
- /package/build/{cjs/types → types}/telemetry.js +0 -0
- /package/build/{cjs/types → types}/transition.d.ts +0 -0
- /package/build/{cjs/types → types}/transition.js +0 -0
|
@@ -1,217 +0,0 @@
|
|
|
1
|
-
import packageJson from '../../package.json';
|
|
2
|
-
import { MapperService } from '../mapper';
|
|
3
|
-
import { StreamDataType, StreamRole } from '../../types/stream';
|
|
4
|
-
import { SpanKind, trace, context, SpanStatusCode } from '../../types/telemetry';
|
|
5
|
-
class TelemetryService {
|
|
6
|
-
constructor(appId, config, metadata, context) {
|
|
7
|
-
this.leg = 1;
|
|
8
|
-
this.appId = appId;
|
|
9
|
-
//these are REQUIRED for job and activity spans
|
|
10
|
-
this.config = config;
|
|
11
|
-
this.metadata = metadata;
|
|
12
|
-
this.context = context;
|
|
13
|
-
}
|
|
14
|
-
getJobParentSpanId() {
|
|
15
|
-
return this.context.metadata.spn;
|
|
16
|
-
}
|
|
17
|
-
getActivityParentSpanId(leg) {
|
|
18
|
-
if (leg === 1) {
|
|
19
|
-
return this.context[this.config.parent].output?.metadata?.l2s;
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
return this.context['$self'].output?.metadata?.l1s;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
getTraceId() {
|
|
26
|
-
return this.context.metadata.trc;
|
|
27
|
-
}
|
|
28
|
-
startJobSpan() {
|
|
29
|
-
const spanName = `JOB/${this.appId}/${this.config.subscribes}/1`;
|
|
30
|
-
const traceId = this.getTraceId();
|
|
31
|
-
const spanId = this.getJobParentSpanId();
|
|
32
|
-
const attributes = this.getSpanAttrs(1);
|
|
33
|
-
const span = this.startSpan(traceId, spanId, spanName, attributes);
|
|
34
|
-
this.jobSpan = span;
|
|
35
|
-
this.setTelemetryContext(span, 1);
|
|
36
|
-
return this;
|
|
37
|
-
}
|
|
38
|
-
startActivitySpan(leg = this.leg) {
|
|
39
|
-
const spanName = `${this.config.type.toUpperCase()}/${this.appId}/${this.metadata.aid}/${leg}`;
|
|
40
|
-
const traceId = this.getTraceId();
|
|
41
|
-
const spanId = this.getActivityParentSpanId(leg);
|
|
42
|
-
const attributes = this.getSpanAttrs(leg);
|
|
43
|
-
const span = this.startSpan(traceId, spanId, spanName, attributes);
|
|
44
|
-
this.setTelemetryContext(span, leg);
|
|
45
|
-
this.span = span;
|
|
46
|
-
return this;
|
|
47
|
-
}
|
|
48
|
-
startStreamSpan(data, role) {
|
|
49
|
-
let type;
|
|
50
|
-
if (role === StreamRole.SYSTEM) {
|
|
51
|
-
type = 'SYSTEM';
|
|
52
|
-
}
|
|
53
|
-
else if (role === StreamRole.WORKER) {
|
|
54
|
-
type = 'EXECUTE';
|
|
55
|
-
}
|
|
56
|
-
else if (data.type === StreamDataType.RESULT || data.type === StreamDataType.RESPONSE) {
|
|
57
|
-
type = 'FANIN';
|
|
58
|
-
}
|
|
59
|
-
else {
|
|
60
|
-
type = 'FANOUT';
|
|
61
|
-
}
|
|
62
|
-
const topic = data.metadata.topic ? `/${data.metadata.topic}` : '';
|
|
63
|
-
const spanName = `${type}/${this.appId}/${data.metadata.aid}${topic}`;
|
|
64
|
-
const attributes = this.getStreamSpanAttrs(data);
|
|
65
|
-
const span = this.startSpan(data.metadata.trc, data.metadata.spn, spanName, attributes);
|
|
66
|
-
this.span = span;
|
|
67
|
-
return this;
|
|
68
|
-
}
|
|
69
|
-
startSpan(traceId, spanId, spanName, attributes) {
|
|
70
|
-
this.traceId = traceId;
|
|
71
|
-
this.spanId = spanId;
|
|
72
|
-
const tracer = trace.getTracer(packageJson.name, packageJson.version);
|
|
73
|
-
let parentContext = this.getParentSpanContext();
|
|
74
|
-
const span = tracer.startSpan(spanName, { kind: SpanKind.CLIENT, attributes, root: !parentContext }, parentContext);
|
|
75
|
-
return span;
|
|
76
|
-
}
|
|
77
|
-
mapActivityAttributes() {
|
|
78
|
-
//export user-defined span attributes (app.activity.data.*)
|
|
79
|
-
if (this.config.telemetry) {
|
|
80
|
-
const telemetryAtts = new MapperService(this.config.telemetry, this.context).mapRules();
|
|
81
|
-
const namespacedAtts = {
|
|
82
|
-
...Object.keys(telemetryAtts).reduce((result, key) => {
|
|
83
|
-
if (['string', 'boolean', 'number'].includes(typeof telemetryAtts[key])) {
|
|
84
|
-
result[`app.activity.data.${key}`] = telemetryAtts[key];
|
|
85
|
-
}
|
|
86
|
-
return result;
|
|
87
|
-
}, {})
|
|
88
|
-
};
|
|
89
|
-
this.span.setAttributes(namespacedAtts);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
setActivityAttributes(attributes) {
|
|
93
|
-
this.span.setAttributes(attributes);
|
|
94
|
-
}
|
|
95
|
-
setStreamAttributes(attributes) {
|
|
96
|
-
this.span.setAttributes(attributes);
|
|
97
|
-
}
|
|
98
|
-
setJobAttributes(attributes) {
|
|
99
|
-
this.jobSpan.setAttributes(attributes);
|
|
100
|
-
}
|
|
101
|
-
endJobSpan() {
|
|
102
|
-
this.endSpan(this.jobSpan);
|
|
103
|
-
}
|
|
104
|
-
endActivitySpan() {
|
|
105
|
-
this.endSpan(this.span);
|
|
106
|
-
}
|
|
107
|
-
endStreamSpan() {
|
|
108
|
-
this.endSpan(this.span);
|
|
109
|
-
}
|
|
110
|
-
endSpan(span) {
|
|
111
|
-
span && span.end();
|
|
112
|
-
}
|
|
113
|
-
getParentSpanContext() {
|
|
114
|
-
if (this.traceId && this.spanId) {
|
|
115
|
-
const restoredSpanContext = {
|
|
116
|
-
traceId: this.traceId,
|
|
117
|
-
spanId: this.spanId,
|
|
118
|
-
isRemote: true,
|
|
119
|
-
traceFlags: 1, // (todo: revisit sampling strategy/config)
|
|
120
|
-
};
|
|
121
|
-
const parentContext = trace.setSpanContext(context.active(), restoredSpanContext);
|
|
122
|
-
return parentContext;
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
getSpanAttrs(leg) {
|
|
126
|
-
return {
|
|
127
|
-
...Object.keys(this.context.metadata).reduce((result, key) => {
|
|
128
|
-
if (key !== 'trc') {
|
|
129
|
-
result[`app.job.${key}`] = this.context.metadata[key];
|
|
130
|
-
}
|
|
131
|
-
return result;
|
|
132
|
-
}, {}),
|
|
133
|
-
...Object.keys(this.metadata).reduce((result, key) => {
|
|
134
|
-
result[`app.activity.${key}`] = this.metadata[key];
|
|
135
|
-
return result;
|
|
136
|
-
}, {}),
|
|
137
|
-
'app.activity.leg': leg,
|
|
138
|
-
};
|
|
139
|
-
}
|
|
140
|
-
;
|
|
141
|
-
getStreamSpanAttrs(input) {
|
|
142
|
-
return {
|
|
143
|
-
...Object.keys(input.metadata).reduce((result, key) => {
|
|
144
|
-
if (key !== 'trc' && key !== 'spn') {
|
|
145
|
-
result[`app.stream.${key}`] = input.metadata[key];
|
|
146
|
-
}
|
|
147
|
-
return result;
|
|
148
|
-
}, {})
|
|
149
|
-
};
|
|
150
|
-
}
|
|
151
|
-
;
|
|
152
|
-
setTelemetryContext(span, leg) {
|
|
153
|
-
if (!this.context.metadata.trc) {
|
|
154
|
-
this.context.metadata.trc = span.spanContext().traceId;
|
|
155
|
-
}
|
|
156
|
-
if (leg === 1) {
|
|
157
|
-
if (!this.context['$self'].output.metadata) {
|
|
158
|
-
this.context['$self'].output.metadata = {};
|
|
159
|
-
}
|
|
160
|
-
this.context['$self'].output.metadata.l1s = span.spanContext().spanId;
|
|
161
|
-
}
|
|
162
|
-
else {
|
|
163
|
-
if (!this.context['$self'].output.metadata) {
|
|
164
|
-
this.context['$self'].output.metadata = {};
|
|
165
|
-
}
|
|
166
|
-
this.context['$self'].output.metadata.l2s = span.spanContext().spanId;
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
setActivityError(message) {
|
|
170
|
-
this.span.setStatus({ code: SpanStatusCode.ERROR, message });
|
|
171
|
-
}
|
|
172
|
-
setStreamError(message) {
|
|
173
|
-
this.span.setStatus({ code: SpanStatusCode.ERROR, message });
|
|
174
|
-
}
|
|
175
|
-
/**
|
|
176
|
-
* Adds the paths (HGET) necessary to restore telemetry state for an activity
|
|
177
|
-
* @param consumes
|
|
178
|
-
* @param config
|
|
179
|
-
* @param metadata
|
|
180
|
-
* @param leg
|
|
181
|
-
*/
|
|
182
|
-
static addTargetTelemetryPaths(consumes, config, metadata, leg) {
|
|
183
|
-
if (leg === 1) {
|
|
184
|
-
if (!(config.parent in consumes)) {
|
|
185
|
-
consumes[config.parent] = [];
|
|
186
|
-
}
|
|
187
|
-
consumes[config.parent].push(`${config.parent}/output/metadata/l2s`);
|
|
188
|
-
}
|
|
189
|
-
else {
|
|
190
|
-
if (!(metadata.aid in consumes)) {
|
|
191
|
-
consumes[metadata.aid] = [];
|
|
192
|
-
}
|
|
193
|
-
consumes[metadata.aid].push(`${metadata.aid}/output/metadata/l1s`);
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
static bindJobTelemetryToState(state, config, context) {
|
|
197
|
-
if (config.type === 'trigger') {
|
|
198
|
-
state['metadata/trc'] = context.metadata.trc;
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
static bindActivityTelemetryToState(state, config, metadata, context, leg) {
|
|
202
|
-
if (config.type === 'trigger') {
|
|
203
|
-
state[`${metadata.aid}/output/metadata/l1s`] = context['$self'].output.metadata.l1s;
|
|
204
|
-
state[`${metadata.aid}/output/metadata/l2s`] = context['$self'].output.metadata.l2s;
|
|
205
|
-
}
|
|
206
|
-
else if (config.type === 'activity' && leg === 1) {
|
|
207
|
-
//activities run non-duplexed and only have a single leg
|
|
208
|
-
state[`${metadata.aid}/output/metadata/l1s`] = context['$self'].output.metadata.l1s;
|
|
209
|
-
state[`${metadata.aid}/output/metadata/l2s`] = context['$self'].output.metadata.l1s;
|
|
210
|
-
}
|
|
211
|
-
else {
|
|
212
|
-
const target = `l${leg}s`;
|
|
213
|
-
state[`${metadata.aid}/output/metadata/${target}`] = context['$self'].output.metadata[target];
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
export { TelemetryService };
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { ILogger } from "../logger";
|
|
2
|
-
import { StreamSignaler } from "../signaler/stream";
|
|
3
|
-
import { StoreService } from '../store';
|
|
4
|
-
import { StreamService } from '../stream';
|
|
5
|
-
import { SubService } from '../sub';
|
|
6
|
-
import { HotMeshConfig, HotMeshWorker } from "../../types/hotmesh";
|
|
7
|
-
import { SubscriptionCallback } from "../../types/quorum";
|
|
8
|
-
import { RedisClient, RedisMulti } from "../../types/redis";
|
|
9
|
-
declare class WorkerService {
|
|
10
|
-
namespace: string;
|
|
11
|
-
appId: string;
|
|
12
|
-
guid: string;
|
|
13
|
-
topic: string;
|
|
14
|
-
config: HotMeshConfig;
|
|
15
|
-
store: StoreService<RedisClient, RedisMulti> | null;
|
|
16
|
-
stream: StreamService<RedisClient, RedisMulti> | null;
|
|
17
|
-
subscribe: SubService<RedisClient, RedisMulti> | null;
|
|
18
|
-
streamSignaler: StreamSignaler | null;
|
|
19
|
-
logger: ILogger;
|
|
20
|
-
reporting: boolean;
|
|
21
|
-
static init(namespace: string, appId: string, guid: string, config: HotMeshConfig, logger: ILogger): Promise<WorkerService[]>;
|
|
22
|
-
verifyWorkerFields(worker: HotMeshWorker): void;
|
|
23
|
-
initStoreChannel(service: WorkerService, store: RedisClient): Promise<void>;
|
|
24
|
-
initSubChannel(service: WorkerService, sub: RedisClient): Promise<void>;
|
|
25
|
-
initStreamChannel(service: WorkerService, stream: RedisClient): Promise<void>;
|
|
26
|
-
initStreamSignaler(worker: HotMeshWorker, logger: ILogger): StreamSignaler;
|
|
27
|
-
subscriptionHandler(): SubscriptionCallback;
|
|
28
|
-
throttle(delayInMillis: number): Promise<void>;
|
|
29
|
-
}
|
|
30
|
-
export { WorkerService };
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import { KeyType } from "../../modules/key";
|
|
2
|
-
import { StreamSignaler } from "../signaler/stream";
|
|
3
|
-
import { RedisStoreService as RedisStore } from '../store/clients/redis';
|
|
4
|
-
import { IORedisStoreService as IORedisStore } from '../store/clients/ioredis';
|
|
5
|
-
import { RedisStreamService as RedisStream } from '../stream/clients/redis';
|
|
6
|
-
import { IORedisStreamService as IORedisStream } from '../stream/clients/ioredis';
|
|
7
|
-
import { IORedisSubService as IORedisSub } from '../sub/clients/ioredis';
|
|
8
|
-
import { RedisSubService as RedisSub } from '../sub/clients/redis';
|
|
9
|
-
import { StreamRole } from "../../types/stream";
|
|
10
|
-
import { identifyRedisType } from "../../modules/utils";
|
|
11
|
-
import { ConnectorService } from "../connector";
|
|
12
|
-
class WorkerService {
|
|
13
|
-
constructor() {
|
|
14
|
-
this.reporting = false;
|
|
15
|
-
}
|
|
16
|
-
static async init(namespace, appId, guid, config, logger) {
|
|
17
|
-
const services = [];
|
|
18
|
-
if (Array.isArray(config.workers)) {
|
|
19
|
-
for (const worker of config.workers) {
|
|
20
|
-
await ConnectorService.initRedisClients(worker.redis?.class, worker.redis?.options, worker);
|
|
21
|
-
const service = new WorkerService();
|
|
22
|
-
service.verifyWorkerFields(worker);
|
|
23
|
-
service.namespace = namespace;
|
|
24
|
-
service.appId = appId;
|
|
25
|
-
service.guid = guid;
|
|
26
|
-
service.topic = worker.topic;
|
|
27
|
-
service.config = config;
|
|
28
|
-
service.logger = logger;
|
|
29
|
-
await service.initStoreChannel(service, worker.store);
|
|
30
|
-
await service.initSubChannel(service, worker.sub);
|
|
31
|
-
await service.subscribe.subscribe(KeyType.QUORUM, service.subscriptionHandler(), appId);
|
|
32
|
-
await service.subscribe.subscribe(KeyType.QUORUM, service.subscriptionHandler(), appId, service.topic);
|
|
33
|
-
await service.subscribe.subscribe(KeyType.QUORUM, service.subscriptionHandler(), appId, service.guid);
|
|
34
|
-
await service.initStreamChannel(service, worker.stream);
|
|
35
|
-
service.streamSignaler = service.initStreamSignaler(worker, logger);
|
|
36
|
-
const key = service.stream.mintKey(KeyType.STREAMS, { appId: service.appId, topic: worker.topic });
|
|
37
|
-
await service.streamSignaler.consumeMessages(key, 'WORKER', service.guid, worker.callback);
|
|
38
|
-
services.push(service);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
return services;
|
|
42
|
-
}
|
|
43
|
-
verifyWorkerFields(worker) {
|
|
44
|
-
if ((!identifyRedisType(worker.store) ||
|
|
45
|
-
!identifyRedisType(worker.stream) ||
|
|
46
|
-
!identifyRedisType(worker.sub)) ||
|
|
47
|
-
!(worker.topic && worker.callback)) {
|
|
48
|
-
throw new Error('worker must include `store`, `stream`, and `sub` fields along with a callback function and topic.');
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
async initStoreChannel(service, store) {
|
|
52
|
-
if (identifyRedisType(store) === 'redis') {
|
|
53
|
-
service.store = new RedisStore(store);
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
service.store = new IORedisStore(store);
|
|
57
|
-
}
|
|
58
|
-
await service.store.init(service.namespace, service.appId, service.logger);
|
|
59
|
-
}
|
|
60
|
-
async initSubChannel(service, sub) {
|
|
61
|
-
if (identifyRedisType(sub) === 'redis') {
|
|
62
|
-
service.subscribe = new RedisSub(sub);
|
|
63
|
-
}
|
|
64
|
-
else {
|
|
65
|
-
service.subscribe = new IORedisSub(sub);
|
|
66
|
-
}
|
|
67
|
-
await service.subscribe.init(service.namespace, service.appId, service.guid, service.logger);
|
|
68
|
-
}
|
|
69
|
-
async initStreamChannel(service, stream) {
|
|
70
|
-
if (identifyRedisType(stream) === 'redis') {
|
|
71
|
-
service.stream = new RedisStream(stream);
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
service.stream = new IORedisStream(stream);
|
|
75
|
-
}
|
|
76
|
-
await service.stream.init(service.namespace, service.appId, service.logger);
|
|
77
|
-
}
|
|
78
|
-
initStreamSignaler(worker, logger) {
|
|
79
|
-
return new StreamSignaler({
|
|
80
|
-
namespace: this.namespace,
|
|
81
|
-
appId: this.appId,
|
|
82
|
-
guid: this.guid,
|
|
83
|
-
role: StreamRole.WORKER,
|
|
84
|
-
topic: worker.topic,
|
|
85
|
-
reclaimDelay: worker.reclaimDelay,
|
|
86
|
-
reclaimCount: worker.reclaimCount,
|
|
87
|
-
}, this.stream, this.store, logger);
|
|
88
|
-
}
|
|
89
|
-
subscriptionHandler() {
|
|
90
|
-
const self = this;
|
|
91
|
-
return async (topic, message) => {
|
|
92
|
-
self.logger.debug('worker-event-received', { topic, type: message.type });
|
|
93
|
-
if (message.type === 'throttle') {
|
|
94
|
-
self.throttle(message.throttle);
|
|
95
|
-
}
|
|
96
|
-
};
|
|
97
|
-
}
|
|
98
|
-
async throttle(delayInMillis) {
|
|
99
|
-
this.streamSignaler.setThrottle(delayInMillis);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
export { WorkerService };
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import { MetricTypes } from "./stats";
|
|
2
|
-
import { StreamRetryPolicy } from "./stream";
|
|
3
|
-
type ActivityExecutionType = 'trigger' | 'await' | 'worker' | 'activity' | 'emit' | 'iterate' | 'cycle';
|
|
4
|
-
type Consumes = Record<string, string[]>;
|
|
5
|
-
interface BaseActivity {
|
|
6
|
-
title?: string;
|
|
7
|
-
type?: ActivityExecutionType;
|
|
8
|
-
subtype?: string;
|
|
9
|
-
input?: Record<string, any>;
|
|
10
|
-
output?: Record<string, any>;
|
|
11
|
-
settings?: Record<string, any>;
|
|
12
|
-
job?: Record<string, any>;
|
|
13
|
-
hook?: Record<string, any>;
|
|
14
|
-
telemetry?: Record<string, any>;
|
|
15
|
-
sleep?: number;
|
|
16
|
-
expire?: number;
|
|
17
|
-
retry?: StreamRetryPolicy;
|
|
18
|
-
cycle?: boolean;
|
|
19
|
-
collationInt?: number;
|
|
20
|
-
consumes?: Consumes;
|
|
21
|
-
PRODUCES?: string[];
|
|
22
|
-
produces?: string[];
|
|
23
|
-
publishes?: string;
|
|
24
|
-
subscribes?: string;
|
|
25
|
-
trigger?: string;
|
|
26
|
-
parent?: string;
|
|
27
|
-
ancestors?: string[];
|
|
28
|
-
}
|
|
29
|
-
interface Measure {
|
|
30
|
-
measure: MetricTypes;
|
|
31
|
-
target: string;
|
|
32
|
-
}
|
|
33
|
-
interface TriggerActivityStats {
|
|
34
|
-
id?: {
|
|
35
|
-
[key: string]: unknown;
|
|
36
|
-
} | string;
|
|
37
|
-
key?: {
|
|
38
|
-
[key: string]: unknown;
|
|
39
|
-
} | string;
|
|
40
|
-
measures?: Measure[];
|
|
41
|
-
}
|
|
42
|
-
interface TriggerActivity extends BaseActivity {
|
|
43
|
-
type: 'trigger';
|
|
44
|
-
stats?: TriggerActivityStats;
|
|
45
|
-
}
|
|
46
|
-
interface AwaitActivity extends BaseActivity {
|
|
47
|
-
type: 'await';
|
|
48
|
-
eventName: string;
|
|
49
|
-
timeout: number;
|
|
50
|
-
}
|
|
51
|
-
interface WorkerActivity extends BaseActivity {
|
|
52
|
-
type: 'worker';
|
|
53
|
-
topic: string;
|
|
54
|
-
timeout: number;
|
|
55
|
-
}
|
|
56
|
-
interface EmitActivity extends BaseActivity {
|
|
57
|
-
type: 'emit';
|
|
58
|
-
}
|
|
59
|
-
interface CycleActivity extends BaseActivity {
|
|
60
|
-
type: 'cycle';
|
|
61
|
-
ancestor: string;
|
|
62
|
-
}
|
|
63
|
-
interface IterateActivity extends BaseActivity {
|
|
64
|
-
type: 'iterate';
|
|
65
|
-
}
|
|
66
|
-
type ActivityType = BaseActivity | TriggerActivity | AwaitActivity | WorkerActivity | EmitActivity | IterateActivity;
|
|
67
|
-
type ActivityData = Record<string, any>;
|
|
68
|
-
type ActivityMetadata = {
|
|
69
|
-
aid: string;
|
|
70
|
-
atp: string;
|
|
71
|
-
stp: string;
|
|
72
|
-
ac: string;
|
|
73
|
-
au: string;
|
|
74
|
-
err?: string;
|
|
75
|
-
l1s?: string;
|
|
76
|
-
l2s?: string;
|
|
77
|
-
dad?: string;
|
|
78
|
-
as?: string;
|
|
79
|
-
};
|
|
80
|
-
type ActivityContext = {
|
|
81
|
-
data?: ActivityData | null;
|
|
82
|
-
metadata: ActivityMetadata;
|
|
83
|
-
hook?: ActivityData;
|
|
84
|
-
};
|
|
85
|
-
type ActivityDuplex = 1 | 2;
|
|
86
|
-
type ActivityDataType = {
|
|
87
|
-
data?: Record<string, unknown>;
|
|
88
|
-
metadata?: Record<string, unknown>;
|
|
89
|
-
hook?: Record<string, unknown>;
|
|
90
|
-
};
|
|
91
|
-
type ActivityLeg = 1 | 2;
|
|
92
|
-
export { ActivityContext, ActivityData, ActivityDataType, ActivityDuplex, ActivityLeg, ActivityMetadata, ActivityType, Consumes, TriggerActivityStats, AwaitActivity, CycleActivity, BaseActivity, EmitActivity, IterateActivity, TriggerActivity, WorkerActivity };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/build/esm/types/app.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
interface App {
|
|
2
|
-
name: string;
|
|
3
|
-
title: string;
|
|
4
|
-
description: string;
|
|
5
|
-
}
|
|
6
|
-
type AppVID = {
|
|
7
|
-
version: string;
|
|
8
|
-
id: string;
|
|
9
|
-
};
|
|
10
|
-
type AppTransitions = {
|
|
11
|
-
[key: string]: Record<string, unknown>;
|
|
12
|
-
};
|
|
13
|
-
type AppSubscriptions = {
|
|
14
|
-
[key: string]: string;
|
|
15
|
-
};
|
|
16
|
-
export { App, AppVID, AppTransitions, AppSubscriptions };
|
package/build/esm/types/app.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/build/esm/types/async.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export type CacheMode = 'nocache' | 'cache';
|
package/build/esm/types/cache.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export var CollationFaultType;
|
|
2
|
-
(function (CollationFaultType) {
|
|
3
|
-
CollationFaultType["MISSING"] = "missing";
|
|
4
|
-
CollationFaultType["DUPLICATE"] = "duplicate";
|
|
5
|
-
CollationFaultType["INACTIVE"] = "inactive";
|
|
6
|
-
CollationFaultType["INVALID"] = "invalid";
|
|
7
|
-
CollationFaultType["FORBIDDEN"] = "forbidden";
|
|
8
|
-
})(CollationFaultType || (CollationFaultType = {}));
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { RedisClass, RedisOptions } from './redis';
|
|
2
|
-
type WorkflowOptions = {
|
|
3
|
-
taskQueue: string;
|
|
4
|
-
args: any[];
|
|
5
|
-
workflowId: string;
|
|
6
|
-
workflowName?: string;
|
|
7
|
-
workflowTrace?: string;
|
|
8
|
-
workflowSpan?: string;
|
|
9
|
-
};
|
|
10
|
-
type ActivityDataType = {
|
|
11
|
-
activityName: string;
|
|
12
|
-
arguments: any[];
|
|
13
|
-
workflowId: string;
|
|
14
|
-
workflowTopic: string;
|
|
15
|
-
};
|
|
16
|
-
type WorkflowDataType = {
|
|
17
|
-
arguments: any[];
|
|
18
|
-
workflowId: string;
|
|
19
|
-
workflowTopic: string;
|
|
20
|
-
};
|
|
21
|
-
type ConnectionConfig = {
|
|
22
|
-
class: RedisClass;
|
|
23
|
-
options: RedisOptions;
|
|
24
|
-
};
|
|
25
|
-
type Connection = ConnectionConfig;
|
|
26
|
-
type NativeConnection = ConnectionConfig;
|
|
27
|
-
type ClientConfig = {
|
|
28
|
-
connection: Connection;
|
|
29
|
-
};
|
|
30
|
-
type Registry = {
|
|
31
|
-
[key: string]: Function;
|
|
32
|
-
};
|
|
33
|
-
type WorkerConfig = {
|
|
34
|
-
connection: Connection;
|
|
35
|
-
namespace: string;
|
|
36
|
-
taskQueue: string;
|
|
37
|
-
workflowsPath: string;
|
|
38
|
-
activities: {
|
|
39
|
-
[key: string]: Function;
|
|
40
|
-
};
|
|
41
|
-
};
|
|
42
|
-
type ContextType = {
|
|
43
|
-
workflowId: string;
|
|
44
|
-
workflowTopic: string;
|
|
45
|
-
};
|
|
46
|
-
type FunctionSignature<T> = T extends (...args: infer A) => infer R ? (...args: A) => R : never;
|
|
47
|
-
type ProxyType<ACT> = {
|
|
48
|
-
[K in keyof ACT]: FunctionSignature<ACT[K]>;
|
|
49
|
-
};
|
|
50
|
-
type ActivityConfig = {
|
|
51
|
-
startToCloseTimeout: string;
|
|
52
|
-
retryPolicy: {
|
|
53
|
-
initialInterval: string;
|
|
54
|
-
maximumAttempts: number;
|
|
55
|
-
backoffCoefficient: number;
|
|
56
|
-
maximumInterval: string;
|
|
57
|
-
};
|
|
58
|
-
};
|
|
59
|
-
export { ActivityConfig, ActivityDataType, ClientConfig, ContextType, ConnectionConfig, Connection, NativeConnection, ProxyType, Registry, WorkerConfig, WorkflowDataType, WorkflowOptions, };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
interface HookCondition {
|
|
2
|
-
expected: string;
|
|
3
|
-
actual: string;
|
|
4
|
-
}
|
|
5
|
-
declare enum HookGate {
|
|
6
|
-
AND = "and",
|
|
7
|
-
OR = "or"
|
|
8
|
-
}
|
|
9
|
-
interface HookConditions {
|
|
10
|
-
gate?: HookGate;
|
|
11
|
-
match: HookCondition[];
|
|
12
|
-
}
|
|
13
|
-
interface HookRule {
|
|
14
|
-
to: string;
|
|
15
|
-
conditions: HookConditions;
|
|
16
|
-
}
|
|
17
|
-
interface HookRules {
|
|
18
|
-
[eventName: string]: HookRule[];
|
|
19
|
-
}
|
|
20
|
-
type HookSignal = {
|
|
21
|
-
topic: string;
|
|
22
|
-
resolved: string;
|
|
23
|
-
jobId: string;
|
|
24
|
-
};
|
|
25
|
-
interface HookInterface {
|
|
26
|
-
(topic: string, data: {
|
|
27
|
-
[key: string]: any;
|
|
28
|
-
id: string;
|
|
29
|
-
}): Promise<void>;
|
|
30
|
-
}
|
|
31
|
-
export { HookCondition, HookConditions, HookGate, HookInterface, HookRule, HookRules, HookSignal };
|
package/build/esm/types/hook.js
DELETED
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import { ILogger } from '../services/logger';
|
|
2
|
-
import { HotMeshService } from '../services/hotmesh';
|
|
3
|
-
import { HookRules } from './hook';
|
|
4
|
-
import { RedisClass, RedisClient, RedisOptions } from './redis';
|
|
5
|
-
import { StreamData, StreamDataResponse } from './stream';
|
|
6
|
-
type HotMesh = typeof HotMeshService;
|
|
7
|
-
type RedisConfig = {
|
|
8
|
-
class: RedisClass;
|
|
9
|
-
options: RedisOptions;
|
|
10
|
-
};
|
|
11
|
-
type HotMeshEngine = {
|
|
12
|
-
store?: RedisClient;
|
|
13
|
-
stream?: RedisClient;
|
|
14
|
-
sub?: RedisClient;
|
|
15
|
-
redis?: RedisConfig;
|
|
16
|
-
reclaimDelay?: number;
|
|
17
|
-
reclaimCount?: number;
|
|
18
|
-
};
|
|
19
|
-
type HotMeshWorker = {
|
|
20
|
-
topic: string;
|
|
21
|
-
store?: RedisClient;
|
|
22
|
-
stream?: RedisClient;
|
|
23
|
-
sub?: RedisClient;
|
|
24
|
-
redis?: {
|
|
25
|
-
class: RedisClass;
|
|
26
|
-
options: RedisOptions;
|
|
27
|
-
};
|
|
28
|
-
reclaimDelay?: number;
|
|
29
|
-
reclaimCount?: number;
|
|
30
|
-
callback: (payload: StreamData) => Promise<StreamDataResponse | void>;
|
|
31
|
-
};
|
|
32
|
-
type HotMeshConfig = {
|
|
33
|
-
appId: string;
|
|
34
|
-
namespace?: string;
|
|
35
|
-
name?: string;
|
|
36
|
-
logger?: ILogger;
|
|
37
|
-
logLevel?: 'silly' | 'debug' | 'info' | 'warn' | 'error' | 'silent';
|
|
38
|
-
engine?: HotMeshEngine;
|
|
39
|
-
workers?: HotMeshWorker[];
|
|
40
|
-
};
|
|
41
|
-
type HotMeshGraph = {
|
|
42
|
-
subscribes: string;
|
|
43
|
-
publishes?: string;
|
|
44
|
-
expire?: number;
|
|
45
|
-
output?: {
|
|
46
|
-
schema: Record<string, any>;
|
|
47
|
-
};
|
|
48
|
-
input?: {
|
|
49
|
-
schema: Record<string, any>;
|
|
50
|
-
};
|
|
51
|
-
activities: Record<string, any>;
|
|
52
|
-
transitions?: Record<string, any>;
|
|
53
|
-
hooks?: HookRules;
|
|
54
|
-
};
|
|
55
|
-
type HotMeshSettings = {
|
|
56
|
-
namespace: string;
|
|
57
|
-
version: string;
|
|
58
|
-
};
|
|
59
|
-
type HotMeshManifest = {
|
|
60
|
-
app: {
|
|
61
|
-
id: string;
|
|
62
|
-
version: string;
|
|
63
|
-
settings: Record<string, any>;
|
|
64
|
-
graphs: HotMeshGraph[];
|
|
65
|
-
};
|
|
66
|
-
};
|
|
67
|
-
type VersionedFields = {
|
|
68
|
-
[K in `versions/${string}`]: any;
|
|
69
|
-
};
|
|
70
|
-
type HotMeshApp = VersionedFields & {
|
|
71
|
-
id: string;
|
|
72
|
-
version: string;
|
|
73
|
-
settings?: string;
|
|
74
|
-
active?: boolean;
|
|
75
|
-
};
|
|
76
|
-
type HotMeshApps = {
|
|
77
|
-
[appId: string]: HotMeshApp;
|
|
78
|
-
};
|
|
79
|
-
export { HotMesh, HotMeshEngine, RedisConfig, HotMeshWorker, HotMeshSettings, HotMeshApp, //a single app in the db
|
|
80
|
-
HotMeshApps, //object array of all apps in the db
|
|
81
|
-
HotMeshConfig, //customer config
|
|
82
|
-
HotMeshManifest, HotMeshGraph };
|