@things-factory/integration-base 6.0.118 → 6.0.120

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.
Files changed (29) hide show
  1. package/dist-server/engine/scenario-engine.js +3 -1
  2. package/dist-server/engine/scenario-engine.js.map +1 -1
  3. package/dist-server/engine/task/graphql-mutate.js +9 -6
  4. package/dist-server/engine/task/graphql-mutate.js.map +1 -1
  5. package/dist-server/engine/task/graphql-query.js +9 -6
  6. package/dist-server/engine/task/graphql-query.js.map +1 -1
  7. package/dist-server/engine/task/index.js +1 -0
  8. package/dist-server/engine/task/index.js.map +1 -1
  9. package/dist-server/engine/task/local-graphql-mutate.js +8 -5
  10. package/dist-server/engine/task/local-graphql-mutate.js.map +1 -1
  11. package/dist-server/engine/task/local-graphql-query.js +8 -5
  12. package/dist-server/engine/task/local-graphql-query.js.map +1 -1
  13. package/dist-server/engine/task/set-domain.js +27 -0
  14. package/dist-server/engine/task/set-domain.js.map +1 -0
  15. package/dist-server/service/scenario-instance/scenario-instance-mutation.js +2 -1
  16. package/dist-server/service/scenario-instance/scenario-instance-mutation.js.map +1 -1
  17. package/dist-server/service/scenario-instance/scenario-instance-type.js +2 -1
  18. package/dist-server/service/scenario-instance/scenario-instance-type.js.map +1 -1
  19. package/dist-server/tsconfig.tsbuildinfo +1 -1
  20. package/package.json +2 -2
  21. package/server/engine/scenario-engine.ts +4 -1
  22. package/server/engine/task/graphql-mutate.ts +9 -6
  23. package/server/engine/task/graphql-query.ts +9 -6
  24. package/server/engine/task/index.ts +1 -0
  25. package/server/engine/task/local-graphql-mutate.ts +8 -5
  26. package/server/engine/task/local-graphql-query.ts +8 -5
  27. package/server/engine/task/set-domain.ts +34 -0
  28. package/server/service/scenario-instance/scenario-instance-mutation.ts +2 -1
  29. package/server/service/scenario-instance/scenario-instance-type.ts +3 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@things-factory/integration-base",
3
- "version": "6.0.118",
3
+ "version": "6.0.120",
4
4
  "main": "dist-server/index.js",
5
5
  "browser": "client/index.js",
6
6
  "things-factory": true,
@@ -46,5 +46,5 @@
46
46
  "devDependencies": {
47
47
  "@types/cron": "^2.0.1"
48
48
  },
49
- "gitHead": "1e7ddc3436e494f42a9428443e834b221c7256bb"
49
+ "gitHead": "6182ee6f7dec8b5b96ff6fc386c2e9dcc25e0186"
50
50
  }
@@ -34,7 +34,9 @@ export class ScenarioEngine {
34
34
  }
35
35
 
36
36
  public static async load(instanceName, scenarioConfig, context?) {
37
- const { domain } = scenarioConfig
37
+ const { domain: scenarioDomain } = scenarioConfig
38
+ const domain = context?.domain || scenarioDomain
39
+
38
40
  debug('load', domain.subdomain, instanceName)
39
41
 
40
42
  var scenarioInstances = ScenarioEngine.scenarioInstances[domain.id]
@@ -78,6 +80,7 @@ export class ScenarioEngine {
78
80
  instance.unload()
79
81
  }
80
82
 
83
+ // will be deprecated soon
81
84
  public static async loadAll() {
82
85
  const SCENARIOS = await getRepository(Scenario).find({
83
86
  where: { active: true },
@@ -8,7 +8,7 @@ import { TaskRegistry } from '../task-registry'
8
8
 
9
9
  async function GraphqlMutate(step, context) {
10
10
  var { connection: connectionName, params: stepOptions } = step
11
- var { mutation, variables: variablesAccessorMap } = stepOptions || {}
11
+ var { mutation, variables: variablesAccessorMap, headers } = stepOptions || {}
12
12
 
13
13
  var { domain, data, variables } = context
14
14
 
@@ -34,7 +34,8 @@ async function GraphqlMutate(step, context) {
34
34
  mutation: gql`
35
35
  ${mutation}
36
36
  `,
37
- variables: queryVariables
37
+ variables: queryVariables,
38
+ headers
38
39
  })
39
40
 
40
41
  return {
@@ -51,10 +52,12 @@ GraphqlMutate.parameterSpec = [
51
52
  {
52
53
  type: 'key-values',
53
54
  name: 'variables',
54
- label: 'variables',
55
- property: {
56
- options: [] //'scenario-step-input'
57
- }
55
+ label: 'variables'
56
+ },
57
+ {
58
+ type: 'key-values',
59
+ name: 'headers',
60
+ label: 'headers'
58
61
  }
59
62
  ]
60
63
  GraphqlMutate.help = 'integration/task/graphql-mutate'
@@ -8,7 +8,7 @@ import { TaskRegistry } from '../task-registry'
8
8
 
9
9
  async function GraphqlQuery(step, context) {
10
10
  var { connection: connectionName, params: stepOptions } = step
11
- var { query, variables: variablesAccessorMap } = stepOptions || {}
11
+ var { query, variables: variablesAccessorMap, headers } = stepOptions || {}
12
12
  var { domain, data, variables } = context
13
13
 
14
14
  const vm = new VM({
@@ -33,7 +33,8 @@ async function GraphqlQuery(step, context) {
33
33
  query: gql`
34
34
  ${query}
35
35
  `,
36
- variables: queryVariables
36
+ variables: queryVariables,
37
+ headers
37
38
  })
38
39
 
39
40
  return {
@@ -50,10 +51,12 @@ GraphqlQuery.parameterSpec = [
50
51
  {
51
52
  type: 'key-values',
52
53
  name: 'variables',
53
- label: 'variables',
54
- property: {
55
- options: [] //'scenario-step-input'
56
- }
54
+ label: 'variables'
55
+ },
56
+ {
57
+ type: 'key-values',
58
+ name: 'headers',
59
+ label: 'headers'
57
60
  }
58
61
  ]
59
62
 
@@ -35,3 +35,4 @@ import './csv-readline'
35
35
  import './data-mapper'
36
36
  import './headless-post'
37
37
  import './headless-scrap'
38
+ import './set-domain'
@@ -9,7 +9,7 @@ import { TaskRegistry } from '../task-registry'
9
9
 
10
10
  async function LocalGraphqlMutate(step, context) {
11
11
  var { params, updaterId } = step
12
- var { mutation, variables: variablesAccessorMap } = params || {}
12
+ var { mutation, variables: variablesAccessorMap, headers } = params || {}
13
13
  var { client, domain, data, variables } = context
14
14
 
15
15
  const user = await getRepository(User).findOne({
@@ -38,6 +38,7 @@ async function LocalGraphqlMutate(step, context) {
38
38
  ${mutation}
39
39
  `,
40
40
  variables: queryVariables,
41
+ headers,
41
42
  context: {
42
43
  state: {
43
44
  domain,
@@ -60,10 +61,12 @@ LocalGraphqlMutate.parameterSpec = [
60
61
  {
61
62
  type: 'key-values',
62
63
  name: 'variables',
63
- label: 'variables',
64
- property: {
65
- options: [] //'scenario-step-input'
66
- }
64
+ label: 'variables'
65
+ },
66
+ {
67
+ type: 'key-values',
68
+ name: 'headers',
69
+ label: 'headers'
67
70
  }
68
71
  ]
69
72
 
@@ -9,7 +9,7 @@ import { TaskRegistry } from '../task-registry'
9
9
 
10
10
  async function LocalGraphqlQuery(step, context) {
11
11
  var { params, updaterId } = step
12
- var { query, variables: variablesAccessorMap } = params || {}
12
+ var { query, variables: variablesAccessorMap, headers } = params || {}
13
13
  var { client, domain, data, variables } = context
14
14
 
15
15
  const user = await getRepository(User).findOne({
@@ -38,6 +38,7 @@ async function LocalGraphqlQuery(step, context) {
38
38
  ${query}
39
39
  `,
40
40
  variables: queryVariables,
41
+ headers,
41
42
  context: {
42
43
  state: {
43
44
  domain,
@@ -60,10 +61,12 @@ LocalGraphqlQuery.parameterSpec = [
60
61
  {
61
62
  type: 'key-values',
62
63
  name: 'variables',
63
- label: 'variables',
64
- property: {
65
- options: [] //'scenario-step-input'
66
- }
64
+ label: 'variables'
65
+ },
66
+ {
67
+ type: 'key-values',
68
+ name: 'headers',
69
+ label: 'headers'
67
70
  }
68
71
  ]
69
72
 
@@ -0,0 +1,34 @@
1
+ import { TaskRegistry } from '../task-registry'
2
+ import { Domain, getRepository } from '@things-factory/shell'
3
+
4
+ async function SetDomain(step, context) {
5
+ var {
6
+ params: { subdomain }
7
+ } = step
8
+
9
+ var { logger, domain } = context || {}
10
+
11
+ logger.info(`domain => ${subdomain}`)
12
+
13
+ if (subdomain) {
14
+ context.domain = (await getRepository(Domain).findOneBy({ subdomain })) || domain
15
+ }
16
+
17
+ return {
18
+ data: domain.subdomain // previous domain
19
+ }
20
+ }
21
+
22
+ SetDomain.parameterSpec = [
23
+ {
24
+ type: 'string',
25
+ name: 'subdomain',
26
+ placeholder: 'subdomain',
27
+ label: 'subdomain'
28
+ }
29
+ ]
30
+
31
+ SetDomain.connectorFree = true
32
+ SetDomain.help = 'integration/task/set-domain'
33
+
34
+ TaskRegistry.registerTaskHandler('set-domain', SetDomain)
@@ -54,6 +54,7 @@ export class ScenarioInstanceMutation {
54
54
  /* 시나리오 인스턴스를 생성한다. */
55
55
  instanceName = instanceName || scenarioName + '-' + String(Date.now())
56
56
  var instance = new ScenarioInstance(instanceName, scenario, {
57
+ domain,
57
58
  variables,
58
59
  client: GraphqlLocalClient.client
59
60
  })
@@ -85,7 +86,7 @@ export class ScenarioInstanceMutation {
85
86
  }
86
87
 
87
88
  instanceName = instanceName || scenarioName
88
- return await ScenarioEngine.load(instanceName, scenario, { variables })
89
+ return await ScenarioEngine.load(instanceName, scenario, { domain, variables })
89
90
  }
90
91
 
91
92
  @Mutation(returns => ScenarioInstance, { nullable: true, description: 'To start new scenario instance' })
@@ -145,7 +145,9 @@ export class ScenarioInstance {
145
145
  }
146
146
  }
147
147
 
148
- constructor(instanceName, { name: scenarioName, steps, domain }, context?) {
148
+ constructor(instanceName, { name: scenarioName, steps, domain: scenarioDomain }, context?) {
149
+ const domain = context?.domain || scenarioDomain
150
+
149
151
  this.instanceName = instanceName
150
152
  this.scenarioName = scenarioName
151
153
  this.steps = orderBy(steps || [], step => step.sequence)