@toa.io/core 0.20.0-dev.2 → 0.20.0-dev.4

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@toa.io/core",
3
- "version": "0.20.0-dev.2",
3
+ "version": "0.20.0-dev.4",
4
4
  "description": "Toa Core",
5
5
  "author": "temich <tema.gurtovoy@gmail.com>",
6
6
  "homepage": "https://github.com/toa-io/toa#readme",
@@ -20,10 +20,10 @@
20
20
  },
21
21
  "dependencies": {
22
22
  "@rsql/parser": "1.2.4",
23
- "@toa.io/console": "0.20.0-dev.2",
24
- "@toa.io/generic": "0.20.0-dev.2",
25
- "@toa.io/yaml": "0.20.0-dev.2",
23
+ "@toa.io/console": "0.20.0-dev.4",
24
+ "@toa.io/generic": "0.20.0-dev.4",
25
+ "@toa.io/yaml": "0.20.0-dev.4",
26
26
  "clone-deep": "4.0.1"
27
27
  },
28
- "gitHead": "3e767a32bf4705bacee7b2e8312ed0b0805a5260"
28
+ "gitHead": "a62b12d77a405d18eb92e879672455b6fb2fd9f2"
29
29
  }
package/src/call.js CHANGED
@@ -15,9 +15,14 @@ class Call extends Connector {
15
15
  this.depends(transmitter)
16
16
  }
17
17
 
18
+ /**
19
+ * @param {toa.core.Request} request
20
+ */
18
21
  async invoke (request = {}) {
19
22
  this.#contract.fit(request)
20
23
 
24
+ request.authentic = true
25
+
21
26
  const { exception, ...reply } = await this.#transmitter.request(request)
22
27
 
23
28
  if (exception) throw exception
@@ -13,7 +13,7 @@ class Request extends Conditions {
13
13
  * @returns {toa.schema.JSON}
14
14
  */
15
15
  static schema (definition) {
16
- const schema = { type: 'object', properties: {}, additionalProperties: true }
16
+ const schema = { type: 'object', properties: { authentic: { type: 'boolean' } }, additionalProperties: true }
17
17
  const required = []
18
18
 
19
19
  if (definition.input !== undefined) {
package/src/operation.js CHANGED
@@ -7,26 +7,31 @@ class Operation extends Connector {
7
7
  scope
8
8
 
9
9
  #cascade
10
- #contract
10
+ #contracts
11
11
  #query
12
12
  #scope
13
13
 
14
- constructor (cascade, scope, contract, query, definition) {
14
+ constructor (cascade, scope, contracts, query, definition) {
15
15
  super()
16
16
 
17
17
  this.scope = scope
18
18
 
19
19
  this.#cascade = cascade
20
- this.#contract = contract
20
+ this.#contracts = contracts
21
21
  this.#query = query
22
22
  this.#scope = definition.scope
23
23
 
24
24
  this.depends(cascade)
25
25
  }
26
26
 
27
+ /**
28
+ * @param {toa.core.Request} request
29
+ * @return {Promise<toa.core.Reply>}
30
+ */
27
31
  async invoke (request) {
28
32
  try {
29
- if (request.query) request.query = this.#query.parse(request.query)
33
+ if (request.authentic !== true) this.#contracts.request.fit(request)
34
+ if ('query' in request) request.query = this.#query.parse(request.query)
30
35
 
31
36
  const store = { request }
32
37
 
@@ -52,7 +57,7 @@ class Operation extends Connector {
52
57
  const { request, state } = store
53
58
  const reply = await this.#cascade.run(request.input, state) || {}
54
59
 
55
- this.#contract.fit(reply)
60
+ this.#contracts.reply.fit(reply)
56
61
 
57
62
  store.reply = reply
58
63
  }
@@ -20,7 +20,8 @@ const schemas = {
20
20
  type: 'object',
21
21
  properties: {
22
22
  input: { type: 'null' },
23
- query: load.sync(resolve(__dirname, '../../src/contract/schemas/query.yaml'))
23
+ query: load.sync(resolve(__dirname, '../../src/contract/schemas/query.yaml')),
24
+ authentic: { type: 'boolean' }
24
25
  },
25
26
  additionalProperties: true
26
27
  }
@@ -17,6 +17,7 @@ declare namespace toa.core {
17
17
  type Request = {
18
18
  input?: any
19
19
  query?: request.Query
20
+ authentic?: boolean
20
21
  }
21
22
 
22
23
  }