bugfix: gather handles interim results from azure

This commit is contained in:
Dave Horton
2022-02-26 14:49:34 -05:00
parent c5d392af6a
commit e30701c4b4

View File

@@ -21,7 +21,7 @@ class TaskGather extends Task {
'speechTimeout', 'timeout', 'say', 'play' 'speechTimeout', 'timeout', 'say', 'play'
].forEach((k) => this[k] = this.data[k]); ].forEach((k) => this[k] = this.data[k]);
this.timeout = (this.timeout || 5) * 1000; this.timeout = (this.timeout || 15) * 1000;
this.interim = this.partialResultCallback; this.interim = this.partialResultCallback;
if (this.data.recognizer) { if (this.data.recognizer) {
const recognizer = this.data.recognizer; const recognizer = this.data.recognizer;
@@ -266,19 +266,30 @@ class TaskGather extends Task {
_onTranscription(cs, ep, evt) { _onTranscription(cs, ep, evt) {
if ('aws' === this.vendor && Array.isArray(evt) && evt.length > 0) evt = evt[0]; if ('aws' === this.vendor && Array.isArray(evt) && evt.length > 0) evt = evt[0];
if ('microsoft' === this.vendor) { if ('microsoft' === this.vendor) {
const nbest = evt.NBest; const final = evt.RecognitionStatus === 'Success';
const newEvent = { if (final) {
is_final: evt.RecognitionStatus === 'Success', const nbest = evt.NBest;
alternatives: [ evt = {
{ is_final: true,
confidence: nbest[0].Confidence, alternatives: [
transcript: nbest[0].Display {
} confidence: nbest[0].Confidence,
] transcript: nbest[0].Display
}; }
evt = newEvent; ]
};
}
else {
evt = {
is_final: false,
alternatives: [
{
transcript: evt.Text
}
]
};
}
} }
this.logger.debug(evt, 'TaskGather:_onTranscription');
if (evt.is_final) this._resolve('speech', evt); if (evt.is_final) this._resolve('speech', evt);
else { else {
if (this.bargein && evt.alternatives[0].transcript.split(' ').length >= this.minBargeinWordCount) { if (this.bargein && evt.alternatives[0].transcript.split(' ').length >= this.minBargeinWordCount) {