2 * Copyright (c) 2011-2014 Samsung Electronics Co., Ltd All Rights Reserved
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 * http://www.apache.org/licenses/LICENSE-2.0
7 * Unless required by applicable law or agreed to in writing, software
8 * distributed under the License is distributed on an "AS IS" BASIS,
9 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10 * See the License for the specific language governing permissions and
11 * limitations under the License.
19 #include "stt_engine.h"
20 #include "sttd_main.h"
21 #include "sttd_client_data.h"
22 #include "sttd_config.h"
23 #include "sttd_recorder.h"
24 #include "sttd_engine_agent.h"
27 #define AUDIO_CREATE_ON_START
30 * Internal data structure
36 bool use_default_engine;
39 typedef struct _sttengine_info {
45 char* engine_setting_path;
50 /* engine base setting */
52 bool silence_detection;
53 bool support_silence_detection;
57 /** stt engine agent init */
58 static bool g_agent_init;
61 static GSList* g_engine_client_list;
62 static GSList* g_engine_list;
64 /** default engine info */
65 static int g_default_engine_id;
66 static char* g_default_language;
67 static bool g_default_silence_detected;
69 static int g_engine_id_count;
71 /** current engine id */
72 static int g_recording_engine_id;
74 /** callback functions */
75 static result_callback g_result_cb;
76 static result_time_callback g_result_time_cb;
77 static silence_dectection_callback g_silence_cb;
80 /** callback functions */
81 void __result_cb(sttp_result_event_e event, const char* type, const char** data, int data_count,
82 const char* msg, void* time_info, void *user_data);
84 bool __result_time_cb(int index, sttp_result_time_event_e event, const char* text,
85 long start_time, long end_time, void* user_data);
87 void __detect_silence_cb(sttp_silence_type_e type, void* user_data);
89 bool __supported_language_cb(const char* language, void* user_data);
91 void __engine_info_cb(const char* engine_uuid, const char* engine_name, const char* setting_ug_name,
92 bool use_network, void* user_data);
98 /** get engine info */
99 int __internal_get_engine_info(const char* filepath, sttengine_info_s** info);
101 int __log_enginelist();
104 * STT Engine Agent Interfaces
106 int sttd_engine_agent_init(result_callback result_cb, result_time_callback time_cb,
107 silence_dectection_callback silence_cb)
109 /* initialize static data */
110 if (NULL == result_cb || NULL == time_cb || NULL == silence_cb) {
111 SLOG(LOG_ERROR, TAG_STTD, "[Engine agent ERROR] Invalid parameter");
112 return STTD_ERROR_INVALID_PARAMETER;
115 g_result_cb = result_cb;
116 g_result_time_cb = time_cb;
117 g_silence_cb = silence_cb;
119 g_default_engine_id = -1;
120 g_default_language = NULL;
121 g_engine_id_count = 1;
122 g_recording_engine_id = -1;
124 if (0 != sttd_config_get_default_language(&(g_default_language))) {
125 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent WARNING] There is No default voice in config");
126 /* Set default voice */
127 g_default_language = strdup("en_US");
129 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Default language is %s", g_default_language);
133 if (0 != sttd_config_get_default_silence_detection(&temp)) {
134 SLOG(LOG_WARN, TAG_STTD, "[Server WARNING] There is no silence detection in config");
135 g_default_silence_detected = true;
137 g_default_silence_detected = (bool)temp;
140 g_agent_init = false;
145 int __engine_agent_clear_engine(sttengine_info_s *engine)
147 if (NULL != engine) {
148 if (NULL != engine->engine_uuid) free(engine->engine_uuid);
149 if (NULL != engine->engine_path) free(engine->engine_path);
150 if (NULL != engine->engine_name) free(engine->engine_name);
151 if (NULL != engine->engine_setting_path)free(engine->engine_setting_path);
152 if (NULL != engine->first_lang) free(engine->first_lang);
160 int sttd_engine_agent_release()
162 /* Release client list */
164 sttengine_client_s *client = NULL;
166 if (g_slist_length(g_engine_client_list) > 0) {
167 /* Get a first item */
168 iter = g_slist_nth(g_engine_client_list, 0);
170 while (NULL != iter) {
171 /* Get handle data from list */
173 g_engine_client_list = g_slist_remove_link(g_engine_client_list, iter);
178 iter = g_slist_nth(g_engine_client_list, 0);
182 g_slist_free(g_engine_client_list);
184 /* Release engine list */
185 sttengine_info_s *engine = NULL;
187 if (0 < g_slist_length(g_engine_list)) {
188 /* Get a first item */
189 iter = g_slist_nth(g_engine_list, 0);
191 while (NULL != iter) {
192 /* Get handle data from list */
194 g_engine_list = g_slist_remove_link(g_engine_list, iter);
196 /* Check engine unload */
197 if (engine->is_loaded) {
198 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Unload engine id(%d)", engine->engine_id);
200 if (0 != stt_engine_deinitialize(engine->engine_id))
201 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to deinitialize engine id(%d)", engine->engine_id);
203 if (0 != stt_engine_unload(engine->engine_id))
204 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to unload engine id(%d)", engine->engine_id);
206 engine->is_loaded = false;
209 __engine_agent_clear_engine(engine);
211 iter = g_slist_nth(g_engine_list, 0);
218 g_agent_init = false;
219 g_default_engine_id = -1;
224 void __engine_info_cb(const char* engine_uuid, const char* engine_name, const char* setting_ug_name,
225 bool use_network, void* user_data)
227 sttengine_info_s* temp = (sttengine_info_s*)user_data;
229 temp->engine_uuid = g_strdup(engine_uuid);
230 temp->engine_name = g_strdup(engine_name);
231 temp->engine_setting_path = g_strdup(setting_ug_name);
232 temp->use_network = use_network;
235 int __internal_get_engine_info(const char* filepath, sttengine_info_s** info)
237 if (NULL == filepath || NULL == info) {
238 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
239 return STTD_ERROR_INVALID_PARAMETER;
246 handle = dlopen(filepath, RTLD_LAZY);
249 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Invalid engine : %s, error(%s)", filepath, (NULL == dlerror()) ? "NULL" : dlerror());
250 return STTD_ERROR_ENGINE_NOT_FOUND;
253 /* link engine to daemon */
254 dlsym(handle, "sttp_load_engine");
255 if ((error = dlerror()) != NULL) {
256 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Invalid engine. Fail to open sttp_load_engine : %s", error);
258 return STTD_ERROR_ENGINE_NOT_FOUND;
261 dlsym(handle, "sttp_unload_engine");
262 if ((error = dlerror()) != NULL) {
263 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Invalid engine. Fail to open sttp_unload_engine : %s", error);
265 return STTD_ERROR_ENGINE_NOT_FOUND;
268 int (*get_engine_info)(sttpe_engine_info_cb callback, void* user_data);
270 get_engine_info = (int (*)(sttpe_engine_info_cb, void*))dlsym(handle, "sttp_get_engine_info");
271 if ((error = dlerror()) != NULL || NULL == get_engine_info) {
272 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent WARNING] Invalid engine. Fail to open sttp_get_engine_info : %s", error);
274 return STTD_ERROR_ENGINE_NOT_FOUND;
277 sttengine_info_s* temp;
278 temp = (sttengine_info_s*)calloc(1, sizeof(sttengine_info_s));
280 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to allocate memory");
282 return STTD_ERROR_OUT_OF_MEMORY;
285 /* get engine info */
286 if (0 != get_engine_info(__engine_info_cb, (void*)temp)) {
287 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get engine info from engine");
290 return STTD_ERROR_ENGINE_NOT_FOUND;
296 temp->engine_id = g_engine_id_count;
299 temp->engine_path = g_strdup(filepath);
300 temp->is_loaded = false;
302 SLOG(LOG_DEBUG, TAG_STTD, "----- Valid Engine");
303 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "Engine id : %d", temp->engine_id);
304 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "Engine uuid : %s", temp->engine_uuid);
305 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "Engine name : %s", temp->engine_name);
306 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "Engine path : %s", temp->engine_path);
307 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "Engine setting path : %s", temp->engine_setting_path);
308 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "Use network : %s", temp->use_network ? "true" : "false");
309 SLOG(LOG_DEBUG, TAG_STTD, "-----");
310 SLOG(LOG_DEBUG, TAG_STTD, " ");
314 return STTD_ERROR_NONE;
317 bool __is_engine(const char* filepath)
320 sttengine_info_s *engine = NULL;
322 if (0 < g_slist_length(g_engine_list)) {
323 /* Get a first item */
324 iter = g_slist_nth(g_engine_list, 0);
326 while (NULL != iter) {
327 /* Get handle data from list */
330 if (0 == strcmp(engine->engine_path, filepath)) {
334 iter = g_slist_next(iter);
341 int sttd_engine_agent_initialize_engine_list()
343 /* Get file name from default engine directory */
347 struct dirent *dirp = NULL;
349 dp = opendir(STT_DEFAULT_ENGINE);
352 ret = readdir_r(dp, &entry, &dirp);
354 SLOG(LOG_ERROR, TAG_STTD, "[File ERROR] Fail to read directory");
359 sttengine_info_s* info;
363 filesize = strlen(STT_DEFAULT_ENGINE) + strlen(dirp->d_name) + 5;
364 filepath = (char*)calloc(filesize, sizeof(char));
366 if (NULL != filepath) {
367 snprintf(filepath, filesize, "%s/%s", STT_DEFAULT_ENGINE, dirp->d_name);
369 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Memory not enough!!");
373 if (false == __is_engine(filepath)) {
374 /* get its info and update engine list */
375 if (0 == __internal_get_engine_info(filepath, &info)) {
376 /* add engine info to g_engine_list */
377 g_engine_list = g_slist_append(g_engine_list, info);
381 if (NULL != filepath)
384 } while (NULL != dirp);
388 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent WARNING] Fail to open default directory");
391 if (0 >= g_slist_length(g_engine_list)) {
392 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] No Engine");
393 return STTD_ERROR_ENGINE_NOT_FOUND;
398 /* Set default engine */
400 sttengine_info_s *engine = NULL;
401 char* cur_engine_uuid = NULL;
402 bool is_default_engine = false;
404 /* get current engine from config */
405 if (0 == sttd_config_get_default_engine(&cur_engine_uuid)) {
406 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] current engine from config : %s", cur_engine_uuid);
408 if (0 < g_slist_length(g_engine_list)) {
409 /* Get a first item */
410 iter = g_slist_nth(g_engine_list, 0);
412 while (NULL != iter) {
413 /* Get handle data from list */
416 if (0 == strcmp(engine->engine_uuid, cur_engine_uuid)) {
417 is_default_engine = true;
418 g_default_engine_id = engine->engine_id;
422 iter = g_slist_next(iter);
426 if (cur_engine_uuid != NULL)
427 free(cur_engine_uuid);
429 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent WARNING] There is not current engine from config");
432 if (false == is_default_engine) {
433 if (0 < g_slist_length(g_engine_list)) {
434 /* Get a first item */
435 iter = g_slist_nth(g_engine_list, 0);
437 /* Get handle data from list */
440 if (NULL != engine) {
441 is_default_engine = true;
442 g_default_engine_id = engine->engine_id;
447 if (NULL != engine) {
448 if (NULL != engine->engine_uuid) {
449 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Default engine Id(%d) uuid(%s)", engine->engine_id, engine->engine_uuid);
451 if (false == is_default_engine) {
452 if (0 != sttd_config_set_default_engine(engine->engine_uuid))
453 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to set default engine ");
457 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Default engine is NULL");
458 return STTD_ERROR_ENGINE_NOT_FOUND;
466 sttengine_info_s* __engine_agent_get_engine_by_id(int engine_id)
469 sttengine_info_s *data = NULL;
471 iter = g_slist_nth(g_engine_list, 0);
473 while (NULL != iter) {
477 if (data->engine_id == engine_id)
480 iter = g_slist_next(iter);
486 sttengine_info_s* __engine_agent_get_engine_by_uuid(const char* engine_uuid)
489 sttengine_info_s *data = NULL;
491 iter = g_slist_nth(g_engine_list, 0);
493 while (NULL != iter) {
497 if (0 == strcmp(data->engine_uuid, engine_uuid))
500 iter = g_slist_next(iter);
506 sttengine_client_s* __engine_agent_get_client(int uid)
509 sttengine_client_s *data = NULL;
511 if (0 < g_slist_length(g_engine_client_list)) {
512 iter = g_slist_nth(g_engine_client_list, 0);
514 while (NULL != iter) {
515 /* Get handle data from list */
518 if (uid == data->uid)
521 iter = g_slist_next(iter);
528 sttengine_info_s* __engine_agent_get_engine_by_uid(int uid)
530 sttengine_client_s *data;
532 data = __engine_agent_get_client(uid);
534 return __engine_agent_get_engine_by_id(data->engine_id);
539 int __engine_agent_check_engine_unload(int engine_id)
541 /* Check the count of client to use this engine */
543 int client_count = 0;
544 sttengine_client_s *data = NULL;
546 if (0 < g_slist_length(g_engine_client_list)) {
547 iter = g_slist_nth(g_engine_client_list, 0);
549 while (NULL != iter) {
550 /* Get handle data from list */
553 if (data->engine_id == engine_id)
556 iter = g_slist_next(iter);
560 if (0 == client_count) {
561 sttengine_info_s* engine = NULL;
562 engine = __engine_agent_get_engine_by_id(engine_id);
563 if (NULL == engine) {
564 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get engine from client(%d)", engine_id);
566 if (engine->is_loaded) {
568 #ifndef AUDIO_CREATE_ON_START
569 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Destroy recorder");
570 if (0 != sttd_recorder_destroy(engine->engine_id))
571 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to destroy recorder(%d)", engine->engine_id);
573 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Unload engine id(%d)", engine_id);
574 if (0 != stt_engine_deinitialize(engine->engine_id))
575 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to deinitialize engine id(%d)", engine->engine_id);
577 if (0 != stt_engine_unload(engine->engine_id))
578 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to unload engine id(%d)", engine->engine_id);
580 engine->is_loaded = false;
588 int sttd_engine_agent_load_current_engine(int uid, const char* engine_uuid)
590 if (false == g_agent_init) {
591 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
592 return STTD_ERROR_OPERATION_FAILED;
595 sttengine_client_s* client = NULL;
596 sttengine_info_s* engine = NULL;
597 int before_engine = -1;
599 client = __engine_agent_get_client(uid);
601 if (NULL == client) {
602 client = (sttengine_client_s*)calloc(1, sizeof(sttengine_client_s));
603 if (NULL == client) {
604 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to allocate memory");
605 return STTD_ERROR_OUT_OF_MEMORY;
610 client->engine_id = -1;
612 g_engine_client_list = g_slist_append(g_engine_client_list, client);
614 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Registered client(%d)", uid);
617 if (NULL == engine_uuid) {
618 /* Set default engine */
619 engine = __engine_agent_get_engine_by_id(g_default_engine_id);
621 if (NULL == engine) {
622 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get default engine : %d", g_default_engine_id);
623 return STTD_ERROR_OPERATION_FAILED;
625 before_engine = client->engine_id;
627 client->engine_id = engine->engine_id;
628 client->use_default_engine = true;
630 /* Set engine by uid */
631 engine = __engine_agent_get_engine_by_uuid(engine_uuid);
633 if (NULL == engine) {
634 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get engine : %s", engine_uuid);
635 return STTD_ERROR_OPERATION_FAILED;
637 before_engine = client->engine_id;
639 client->engine_id = engine->engine_id;
640 client->use_default_engine = false;
643 if (-1 != before_engine) {
644 /* Unload engine if reference count is 0 */
645 __engine_agent_check_engine_unload(before_engine);
648 if (true == engine->is_loaded) {
649 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine] engine id(%d) is already loaded", engine->engine_id);
655 ret = stt_engine_load(engine->engine_id, engine->engine_path);
657 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to load engine : id(%d) path(%s)", engine->engine_id, engine->engine_path);
661 ret = stt_engine_initialize(engine->engine_id, __result_cb, __detect_silence_cb);
663 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to initialize engine : id(%d) path(%s)", engine->engine_id, engine->engine_path);
667 ret = stt_engine_set_silence_detection(engine->engine_id, g_default_silence_detected);
669 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent WARNING] Not support silence detection");
670 engine->support_silence_detection = false;
672 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Silence detection : %s", g_default_silence_detected ? "true" : "false");
673 engine->support_silence_detection = true;
674 engine->silence_detection = g_default_silence_detected;
677 /* Set first language */
678 char* tmp_lang = NULL;
679 ret = stt_engine_get_first_language(engine->engine_id, &tmp_lang);
680 if (0 == ret && NULL != tmp_lang) {
681 engine->first_lang = strdup(tmp_lang);
684 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get first language from engine : %d %s", engine->engine_id, engine->engine_name);
688 #ifndef AUDIO_CREATE_ON_START
690 sttp_audio_type_e atype;
694 ret = stt_engine_get_audio_type(engine->engine_id, &atype, &rate, &channels);
696 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get audio type : %d %s", engine->engine_id, engine->engine_name);
700 ret = sttd_recorder_create(engine->engine_id, uid, atype, channels, rate);
702 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to create recorder : %d %s", engine->engine_id, engine->engine_name);
707 engine->is_loaded = true;
708 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent SUCCESS] The %s(%d) has been loaded !!!", engine->engine_name, engine->engine_id);
713 int sttd_engine_agent_unload_current_engine(int uid)
715 if (false == g_agent_init) {
716 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized ");
717 return STTD_ERROR_OPERATION_FAILED;
724 sttengine_client_s *data = NULL;
726 if (0 < g_slist_length(g_engine_client_list)) {
727 iter = g_slist_nth(g_engine_client_list, 0);
729 while (NULL != iter) {
730 /* Get handle data from list */
734 if (uid == data->uid) {
735 g_engine_client_list = g_slist_remove_link(g_engine_client_list, iter);
736 engine_id = data->engine_id;
742 iter = g_slist_next(iter);
746 if (-1 != engine_id) {
747 __engine_agent_check_engine_unload(engine_id);
753 bool sttd_engine_agent_is_default_engine()
755 if (g_default_engine_id > 0)
761 int sttd_engine_agent_get_engine_list(GSList** engine_list)
763 if (false == g_agent_init) {
764 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
765 return STTD_ERROR_OPERATION_FAILED;
769 sttengine_info_s *data = NULL;
771 iter = g_slist_nth(g_engine_list, 0);
773 SLOG(LOG_DEBUG, TAG_STTD, "----- [Engine Agent] engine list -----");
775 while (NULL != iter) {
776 engine_s* temp_engine;
778 temp_engine = (engine_s*)calloc(1, sizeof(engine_s));
779 if (NULL == temp_engine) {
780 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to allocate memory");
781 return STTD_ERROR_OUT_OF_MEMORY;
786 temp_engine->engine_id = strdup(data->engine_uuid);
787 temp_engine->engine_name = strdup(data->engine_name);
788 temp_engine->ug_name = strdup(data->engine_setting_path);
790 *engine_list = g_slist_append(*engine_list, temp_engine);
792 iter = g_slist_next(iter);
794 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " -- Engine id(%s)", temp_engine->engine_id);
795 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " Engine name(%s)", temp_engine->engine_name);
796 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " Engine ug name(%s)", temp_engine->ug_name);
799 SLOG(LOG_DEBUG, TAG_STTD, "--------------------------------------");
804 int sttd_engine_agent_get_current_engine(int uid, char** engine_uuid)
806 if (false == g_agent_init) {
807 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
808 return STTD_ERROR_OPERATION_FAILED;
811 if (NULL == engine_uuid) {
812 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid parameter");
813 return STTD_ERROR_INVALID_PARAMETER;
816 sttengine_info_s* engine;
817 engine = __engine_agent_get_engine_by_uid(uid);
819 if (NULL == engine) {
820 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
821 return STTD_ERROR_INVALID_PARAMETER;
824 if (false == engine->is_loaded) {
825 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
826 return STTD_ERROR_OPERATION_FAILED;
829 *engine_uuid = strdup(engine->engine_uuid);
834 bool sttd_engine_agent_need_network(int uid)
836 if (false == g_agent_init) {
837 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
838 return STTD_ERROR_OPERATION_FAILED;
841 sttengine_info_s* engine;
842 engine = __engine_agent_get_engine_by_uid(uid);
845 return engine->use_network;
850 int sttd_engine_agent_supported_langs(int uid, GSList** lang_list)
852 if (false == g_agent_init) {
853 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
854 return STTD_ERROR_OPERATION_FAILED;
857 if (NULL == lang_list) {
858 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Input parameter is NULL");
859 return STTD_ERROR_INVALID_PARAMETER;
862 sttengine_info_s* engine = NULL;
863 engine = __engine_agent_get_engine_by_uid(uid);
865 if (NULL == engine) {
866 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
867 return STTD_ERROR_INVALID_PARAMETER;
870 if (false == engine->is_loaded) {
871 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
872 return STTD_ERROR_OPERATION_FAILED;
875 int ret = stt_engine_get_supported_langs(engine->engine_id, lang_list);
877 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] get language list error(%d)", ret);
884 int sttd_engine_agent_get_default_lang(int uid, char** lang)
886 if (false == g_agent_init) {
887 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
888 return STTD_ERROR_OPERATION_FAILED;
892 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
893 return STTD_ERROR_INVALID_PARAMETER;
896 sttengine_info_s* engine = NULL;
897 engine = __engine_agent_get_engine_by_uid(uid);
899 if (NULL == engine) {
900 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
901 return STTD_ERROR_INVALID_PARAMETER;
904 if (false == engine->is_loaded) {
905 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
906 return STTD_ERROR_OPERATION_FAILED;
909 /* get default language */
910 bool is_valid = false;
912 ret = stt_engine_is_valid_language(engine->engine_id, g_default_language, &is_valid);
914 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to check valid language");
918 if (true == is_valid) {
919 *lang = strdup(g_default_language);
921 *lang = strdup(engine->first_lang);
926 int sttd_engine_agent_get_option_supported(int uid, bool* silence)
928 if (false == g_agent_init) {
929 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
930 return STTD_ERROR_OPERATION_FAILED;
933 if (NULL == silence) {
934 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
935 return STTD_ERROR_INVALID_PARAMETER;
938 sttengine_info_s* engine = NULL;
939 engine = __engine_agent_get_engine_by_uid(uid);
941 if (NULL == engine) {
942 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] uid(%d) is not valid", uid);
943 return STTD_ERROR_INVALID_PARAMETER;
946 if (false == engine->is_loaded) {
947 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
948 return STTD_ERROR_OPERATION_FAILED;
951 *silence = engine->support_silence_detection;
956 int sttd_engine_agent_is_credential_needed(int uid, bool* credential)
958 if (false == g_agent_init) {
959 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
960 return STTD_ERROR_OPERATION_FAILED;
963 if (NULL == credential) {
964 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
965 return STTD_ERROR_INVALID_PARAMETER;
968 sttengine_info_s* engine = NULL;
969 engine = __engine_agent_get_engine_by_uid(uid);
971 if (NULL == engine) {
972 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] uid(%d) is not valid", uid);
973 return STTD_ERROR_INVALID_PARAMETER;
976 if (false == engine->is_loaded) {
977 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
978 return STTD_ERROR_OPERATION_FAILED;
984 ret = stt_engine_need_app_credential(engine->engine_id, &temp);
986 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get to support recognition type : %d", ret);
994 int sttd_engine_agent_is_recognition_type_supported(int uid, const char* type, bool* support)
996 if (false == g_agent_init) {
997 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
998 return STTD_ERROR_OPERATION_FAILED;
1001 if (NULL == type || NULL == support) {
1002 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
1003 return STTD_ERROR_INVALID_PARAMETER;
1006 sttengine_info_s* engine = NULL;
1007 engine = __engine_agent_get_engine_by_uid(uid);
1009 if (NULL == engine) {
1010 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1011 return STTD_ERROR_INVALID_PARAMETER;
1014 if (false == engine->is_loaded) {
1015 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1016 return STTD_ERROR_OPERATION_FAILED;
1022 ret = stt_engine_support_recognition_type(engine->engine_id, type, &temp);
1024 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get to support recognition type : %d", ret);
1034 * STT Engine Interfaces for client
1037 int __set_option(sttengine_info_s* engine, int silence)
1042 /* Check silence detection */
1043 if (engine->support_silence_detection) {
1045 /* default option set */
1046 if (g_default_silence_detected != engine->silence_detection) {
1047 if (0 != stt_engine_set_silence_detection(engine->engine_id, g_default_silence_detected)) {
1048 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to set silence detection : %s", g_default_silence_detected ? "true" : "false");
1050 engine->silence_detection = g_default_silence_detected;
1051 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Set silence detection : %s", g_default_silence_detected ? "true" : "false");
1055 if (silence != engine->silence_detection) {
1056 if (0 != stt_engine_set_silence_detection(engine->engine_id, silence)) {
1057 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to set silence detection : %s", silence ? "true" : "false");
1059 engine->silence_detection = silence;
1060 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Set silence detection : %s", silence ? "true" : "false");
1069 int sttd_engine_agent_recognize_start_engine(int uid, const char* lang, const char* recognition_type,
1070 int silence, const char* credential, void* user_param)
1072 if (false == g_agent_init) {
1073 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1074 return STTD_ERROR_OPERATION_FAILED;
1077 if (NULL == lang || NULL == recognition_type) {
1078 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
1079 return STTD_ERROR_INVALID_PARAMETER;
1082 sttengine_info_s* engine = NULL;
1083 engine = __engine_agent_get_engine_by_uid(uid);
1085 if (NULL == engine) {
1086 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1087 return STTD_ERROR_INVALID_PARAMETER;
1090 if (false == engine->is_loaded) {
1091 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1092 return STTD_ERROR_OPERATION_FAILED;
1095 if (0 != __set_option(engine, silence)) {
1096 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to set options");
1097 return STTD_ERROR_OPERATION_FAILED;
1100 SLOG(LOG_DEBUG, TAG_STTD, "g_default_language %s", g_default_language);
1104 if (0 == strncmp(lang, "default", strlen("default"))) {
1105 bool is_valid = false;
1106 ret = stt_engine_is_valid_language(engine->engine_id, g_default_language, &is_valid);
1108 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to check valid language");
1112 if (true == is_valid) {
1113 temp = strdup(g_default_language);
1114 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent DEBUG] Default language is %s", temp);
1116 temp = strdup(engine->first_lang);
1117 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent DEBUG] Default language is engine first lang : %s", temp);
1120 temp = strdup(lang);
1123 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Start engine");
1125 ret = stt_engine_recognize_start(engine->engine_id, temp, recognition_type, credential, user_param);
1126 if (NULL != temp) free(temp);
1128 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Recognition start error(%d)", ret);
1129 sttd_recorder_destroy(engine->engine_id);
1133 #ifdef AUDIO_CREATE_ON_START
1134 /* Ready recorder */
1135 sttp_audio_type_e atype;
1139 ret = stt_engine_get_audio_type(engine->engine_id, &atype, &rate, &channels);
1141 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get audio type : %d %s", engine->engine_id, engine->engine_name);
1145 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Create recorder");
1147 ret = sttd_recorder_create(engine->engine_id, uid, atype, channels, rate);
1149 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to create recorder : %d %s", engine->engine_id, engine->engine_name);
1155 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Start recorder");
1157 ret = sttd_recorder_start(engine->engine_id);
1159 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to start recorder : result(%d)", ret);
1163 g_recording_engine_id = engine->engine_id;
1164 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] g_recording_engine_id : %d", g_recording_engine_id);
1170 int sttd_engine_agent_recognize_start_recorder(int uid)
1172 sttengine_info_s* engine = NULL;
1173 engine = __engine_agent_get_engine_by_uid(uid);
1175 if (NULL == engine) {
1176 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1177 return STTD_ERROR_INVALID_PARAMETER;
1180 if (false == engine->is_loaded) {
1181 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1182 return STTD_ERROR_OPERATION_FAILED;
1185 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Start recorder");
1188 ret = sttd_recorder_start(engine->engine_id);
1190 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to start recorder : result(%d)", ret);
1191 stt_engine_recognize_cancel(engine->engine_id);
1192 sttd_recorder_stop(engine->engine_id);
1196 g_recording_engine_id = engine->engine_id;
1197 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] g_recording_engine_id : %d", g_recording_engine_id);
1202 int sttd_engine_agent_set_recording_data(int uid, const void* data, unsigned int length)
1204 if (false == g_agent_init) {
1205 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1206 return STTD_ERROR_OPERATION_FAILED;
1209 if (NULL == data || 0 == length) {
1210 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
1211 return STTD_ERROR_INVALID_PARAMETER;
1214 sttengine_info_s* engine = NULL;
1215 engine = __engine_agent_get_engine_by_uid(uid);
1217 if (NULL == engine) {
1218 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1219 return STTD_ERROR_INVALID_PARAMETER;
1222 if (false == engine->is_loaded) {
1223 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1224 return STTD_ERROR_OPERATION_FAILED;
1227 int ret = stt_engine_set_recording_data(engine->engine_id, data, length);
1229 SLOG(LOG_WARN, TAG_STTD, "[Engine Agent WARNING] set recording error(%d)", ret);
1236 int sttd_engine_agent_recognize_stop_recorder(int uid)
1238 if (false == g_agent_init) {
1239 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1240 return STTD_ERROR_OPERATION_FAILED;
1243 sttengine_info_s* engine = NULL;
1244 engine = __engine_agent_get_engine_by_uid(uid);
1246 if (NULL == engine) {
1247 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1248 return STTD_ERROR_INVALID_PARAMETER;
1251 if (false == engine->is_loaded) {
1252 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1253 return STTD_ERROR_OPERATION_FAILED;
1256 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Stop recorder");
1258 ret = sttd_recorder_stop(engine->engine_id);
1260 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to stop recorder : result(%d)", ret);
1264 #ifdef AUDIO_CREATE_ON_START
1265 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Destroy recorder");
1266 if (0 != sttd_recorder_destroy(engine->engine_id))
1267 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to destroy recorder(%d)", engine->engine_id);
1270 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent Success] Stop recorder");
1274 int sttd_engine_agent_recognize_stop_engine(int uid)
1276 if (false == g_agent_init) {
1277 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1278 return STTD_ERROR_OPERATION_FAILED;
1281 sttengine_info_s* engine = NULL;
1282 engine = __engine_agent_get_engine_by_uid(uid);
1284 if (NULL == engine) {
1285 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1286 return STTD_ERROR_INVALID_PARAMETER;
1289 if (false == engine->is_loaded) {
1290 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1291 return STTD_ERROR_OPERATION_FAILED;
1294 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Stop engine");
1297 ret = stt_engine_recognize_stop(engine->engine_id);
1299 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] stop recognition error(%d)", ret);
1303 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent Success] Stop engine");
1308 int sttd_engine_agent_recognize_cancel(int uid)
1310 if (false == g_agent_init) {
1311 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1312 return STTD_ERROR_OPERATION_FAILED;
1315 sttengine_info_s* engine = NULL;
1316 engine = __engine_agent_get_engine_by_uid(uid);
1318 if (NULL == engine) {
1319 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1320 return STTD_ERROR_INVALID_PARAMETER;
1323 if (false == engine->is_loaded) {
1324 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1325 return STTD_ERROR_OPERATION_FAILED;
1328 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Cancel engine");
1331 ret = stt_engine_recognize_cancel(engine->engine_id);
1333 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] cancel recognition error(%d)", ret);
1337 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Stop recorder");
1339 ret = sttd_recorder_stop(engine->engine_id);
1341 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to stop recorder : result(%d)", ret);
1345 #ifdef AUDIO_CREATE_ON_START
1346 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Destroy recorder");
1347 if (0 != sttd_recorder_destroy(engine->engine_id))
1348 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to destroy recorder(%d)", engine->engine_id);
1351 g_recording_engine_id = -1;
1353 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent Success] Cancel recognition");
1360 * STT Engine Interfaces for configure
1363 int sttd_engine_agent_set_default_engine(const char* engine_uuid)
1365 if (false == g_agent_init) {
1366 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1367 return STTD_ERROR_OPERATION_FAILED;
1370 if (NULL == engine_uuid) {
1371 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
1372 return STTD_ERROR_INVALID_PARAMETER;
1377 sttengine_info_s* engine;
1378 engine = __engine_agent_get_engine_by_uuid(engine_uuid);
1379 if (NULL == engine) {
1380 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Default engine is not valid");
1381 return STTD_ERROR_ENGINE_NOT_FOUND;
1384 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Default engine id(%d) engine uuid(%s)", engine->engine_id, engine->engine_uuid);
1386 g_default_engine_id = engine->engine_id;
1388 /* Update default engine of client */
1389 GSList *iter = NULL;
1390 sttengine_client_s *data = NULL;
1392 if (0 < g_slist_length(g_engine_client_list)) {
1393 iter = g_slist_nth(g_engine_client_list, 0);
1395 while (NULL != iter) {
1396 /* Get handle data from list */
1399 if (true == data->use_default_engine) {
1400 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] uid(%d) change engine from id(%d) to id(%d)",
1401 data->uid, data->engine_id, engine->engine_id);
1403 if (0 != sttd_engine_agent_load_current_engine(data->uid, NULL)) {
1404 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to load current engine : uid(%d)", data->uid);
1408 iter = g_slist_next(iter);
1415 int sttd_engine_agent_set_default_language(const char* language)
1417 if (false == g_agent_init) {
1418 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1419 return STTD_ERROR_OPERATION_FAILED;
1422 if (NULL == language) {
1423 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Invalid Parameter");
1424 return STTD_ERROR_INVALID_PARAMETER;
1427 if (NULL != g_default_language)
1428 free(g_default_language);
1430 g_default_language = strdup(language);
1435 int sttd_engine_agent_set_silence_detection(bool value)
1437 if (false == g_agent_init) {
1438 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1439 return STTD_ERROR_OPERATION_FAILED;
1442 g_default_silence_detected = value;
1447 int sttd_engine_agent_check_app_agreed(int uid, const char* appid, bool* result)
1449 if (false == g_agent_init) {
1450 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not Initialized");
1451 return STTD_ERROR_OPERATION_FAILED;
1454 sttengine_info_s* engine = NULL;
1455 engine = __engine_agent_get_engine_by_uid(uid);
1457 if (NULL == engine) {
1458 SECURE_SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] The engine of uid(%d) is not valid", uid);
1459 return STTD_ERROR_INVALID_PARAMETER;
1462 if (false == engine->is_loaded) {
1463 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Not loaded engine");
1464 return STTD_ERROR_OPERATION_FAILED;
1468 ret = stt_engine_check_app_agreed(engine->engine_id, appid, result);
1470 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] cancel recognition error(%d)", ret);
1475 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Get engine right : %s", *result ? "true" : "false");
1480 * STT Engine Callback Functions ` *
1483 void __result_cb(sttp_result_event_e event, const char* type, const char** data, int data_count,
1484 const char* msg, void* time_info, void *user_data)
1486 if (false == g_agent_init) {
1487 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Result Callback : Not Initialized");
1491 SLOG(LOG_DEBUG, TAG_STTD, "[Server] === Result time callback ===");
1493 if (NULL != time_info) {
1494 /* Get the time info */
1495 int ret = stt_engine_foreach_result_time(g_recording_engine_id, time_info, __result_time_cb, NULL);
1497 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Fail to get time info : %d", ret);
1501 SLOG(LOG_DEBUG, TAG_STTD, "[Server] ============================");
1503 g_result_cb(event, type, data, data_count, msg, user_data);
1505 #ifdef AUDIO_CREATE_ON_START
1506 if (event == STTP_RESULT_EVENT_ERROR) {
1507 SLOG(LOG_DEBUG, TAG_STTD, "[Engine Agent] Destroy recorder");
1508 if (0 != sttd_recorder_destroy(g_recording_engine_id))
1509 SECURE_SLOG(LOG_WARN, TAG_STTD, "[Engine Agent] Fail to destroy recorder(%d)", g_recording_engine_id);
1513 if (event == STTP_RESULT_EVENT_FINAL_RESULT || event == STTP_RESULT_EVENT_ERROR) {
1514 g_recording_engine_id = -1;
1520 bool __result_time_cb(int index, sttp_result_time_event_e event, const char* text, long start_time, long end_time, void* user_data)
1522 return g_result_time_cb(index, event, text, start_time, end_time, user_data);
1525 void __detect_silence_cb(sttp_silence_type_e type, void* user_data)
1527 if (false == g_agent_init) {
1528 SLOG(LOG_ERROR, TAG_STTD, "[Engine Agent ERROR] Silence Callback : Not Initialized");
1532 g_silence_cb(type, user_data);
1536 /* A function forging */
1537 int __log_enginelist()
1539 GSList *iter = NULL;
1540 sttengine_info_s *data = NULL;
1542 if (0 < g_slist_length(g_engine_list)) {
1544 /* Get a first item */
1545 iter = g_slist_nth(g_engine_list, 0);
1547 SLOG(LOG_DEBUG, TAG_STTD, "--------------- engine list -------------------");
1550 while (NULL != iter) {
1551 /* Get handle data from list */
1554 SECURE_SLOG(LOG_DEBUG, TAG_STTD, "[%dth]", i);
1555 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " engine uuid : %s", data->engine_uuid);
1556 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " engine name : %s", data->engine_name);
1557 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " engine path : %s", data->engine_path);
1558 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " use network : %s", data->use_network ? "true" : "false");
1559 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " is loaded : %s", data->is_loaded ? "true" : "false");
1560 if (NULL != data->first_lang)
1561 SECURE_SLOG(LOG_DEBUG, TAG_STTD, " default lang : %s", data->first_lang);
1563 iter = g_slist_next(iter);
1566 SLOG(LOG_DEBUG, TAG_STTD, "----------------------------------------------");
1568 SLOG(LOG_DEBUG, TAG_STTD, "-------------- engine list -------------------");
1569 SLOG(LOG_DEBUG, TAG_STTD, " No Engine in engine directory");
1570 SLOG(LOG_DEBUG, TAG_STTD, "----------------------------------------------");