Required
In the TEN framework, only message schemas are allowed to have required
fields, and the properties of extensions are currently not permitted to include required
fields.
This means that the schemas for cmd_in
, cmd_out
, data_in
, data_out
, audio_frame_in
, audio_frame_out
, video_frame_in
, and video_frame_out
are allowed to have required
fields.
For message schemas, the required
field can only appear in three specific places:
At the same level as the
property
in<foo>_in
/<foo>_out
.Within the
property
ofresult
in<foo>_in
/<foo>_out
.Inside
property
with a type ofobject
(i.e., in nested cases).
Examples of these three scenarios are shown below.
Use of required
required
When a Message is Sent from an Extension
When extension calls send_<foo>(msg_X)
or return_result(result_Y)
, the framework checks msg_X
or result_Y
against their respective schemas in extension. If msg_X
or result_Y
is missing any of the fields marked as required
in the schema, the schema check fails, indicating an error.
The handling of these three scenarios is identical, though they are discussed separately:
If
send_<foo>
is sending a TEN command and the schema check fails:send_<foo>
will return false immediately, and if an error parameter is provided, it will include the schema check failure error message.If
return_result
fails the schema check:return_result
will return false, and if an error parameter is provided, it can include the schema check failure error message.If
send_<foo>
is sending a general data-like TEN message (such as data, audio frame, or video frame):send_<foo>
will return false, and if an error parameter is provided, it can include the schema check failure error message.
When a Message is Received by an Extension
Before ten_runtime passes msg_X
or result_Y
to an extension's on_<foo>()
or result handler, it checks whether all required
fields defined in the schema of msg_X
or result_Y
are present. If any required
field is missing, the schema check fails.
If the incoming message is a TEN command:
ten_runtime will return an error
status_code
result to the previous extension.If the incoming message is a TEN command result:
ten_runtime will change the
status_code
of the result to error, add the missingrequired
fields, and set the values of these fields to their default values based on their type.If the incoming message is a TEN data-like message:
ten_runtime will simply drop the data-like message.
Behavior of Graph Check
TEN Manager has a function called Graph Check, which is used to verify the semantic correctness of a graph. The checks related to required fields are as follows:
For a connection, the
required
fields of the source must be a superset of therequired
fields of the destination.If the same field name appears in both the source and destination
required
fields, their types must be compatible.
Last updated