2 * Copyright (c) 2011-2015 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the License);
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an AS IS BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 #include <app_control.h>
18 #include <app_manager.h>
21 #include <sound_manager.h>
24 #include "vc_cmd_db.h"
25 #include "vc_info_parser.h"
27 #include "vcd_server.h"
28 #include "vcd_server_data.h"
29 #include "vcd_client_data.h"
31 #include "vcd_engine_agent.h"
32 #include "vcd_config.h"
33 #include "vcd_recorder.h"
35 #include "vce_internal.h"
37 #include "voice_control_command_expand.h"
38 #include "voice_control_common.h"
40 #define CLIENT_CLEAN_UP_TIME 500
42 * VC Server static variable
44 static GList *g_proc_list = NULL;
46 static Ecore_Timer *g_restart_timer = NULL;
47 static Ecore_Timer *g_check_widget_client_timer = NULL;
48 static Ecore_Timer *g_check_client_timer = NULL;
50 static Ecore_Thread* g_tts_thread = NULL;
51 static int g_current_uid = -1;
52 static int g_current_utt_id = -1;
55 * @brief Enumerations of send event type.
58 VCD_SEND_EVENT_TYPE_TEXT, /**< send text event to vc engine*/
59 VCD_SEND_EVENT_TYPE_LIST_EVENT, /**< send list event to vc engine */
60 VCD_SEND_EVENT_TYPE_HAPTIC_EVENT /**< send haptic event to vc engine */
61 } vcd_send_event_type_e;
63 static int __vcd_server_launch_manager_app();
64 static int __start_internal_recognition();
67 * VC Server Internal Functions
69 static Eina_Bool __stop_by_silence(void *data)
71 SLOG(LOG_INFO, TAG_VCD, "@@@ Silence Detected ");
73 vcd_server_mgr_stop();
75 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
79 static Eina_Bool __cancel_by_interrupt(void *data)
81 SLOG(LOG_INFO, TAG_VCD, "@@@ Cancel by interrupt");
83 vcd_server_mgr_cancel();
85 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
89 static void __cancel_by_error(void *data)
91 SLOG(LOG_INFO, TAG_VCD, "@@@ Cancel by error");
93 vcd_server_mgr_cancel();
95 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
99 static Eina_Bool __restart_engine(void *data)
101 SLOG(LOG_INFO, TAG_VCD, "@@@ Restart by no result");
103 g_restart_timer = NULL;
105 /* Restart recognition */
106 int ret = vcd_engine_recognize_start(true);
108 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to restart recognition : result(%d)", ret);
112 SLOG(LOG_INFO, TAG_VCD, "[Server Success] Start engine");
114 vcd_recognition_mode_e mode = vcd_client_get_recognition_mode();
115 if (VCD_RECOGNITION_MODE_RESTART_AFTER_REJECT == mode || VCD_RECOGNITION_MODE_RESTART_CONTINUOUSLY == mode) {
116 vcd_config_set_service_state(VCD_STATE_RECORDING);
117 vcdc_send_service_state(VCD_STATE_RECORDING);
120 SLOG(LOG_INFO, TAG_VCD, "[Server Success] Restart recognition");
122 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
126 static int __server_recorder_callback(const void* data, const unsigned int length)
128 vcd_state_e state = vcd_config_get_service_state();
129 if (VCD_STATE_READY == state) {
130 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Ready state, but recording");
131 } else if (VCD_STATE_PROCESSING == state) {
135 vce_speech_detect_e speech_detected = VCE_SPEECH_DETECT_NONE;
138 ret = vcd_engine_recognize_audio(data, length, &speech_detected);
142 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set recording data to engine(%d)", ret);
143 ecore_timer_add(0, __cancel_by_interrupt, NULL);
144 /* Send error cb to manager */
145 if (VCE_ERROR_OUT_OF_NETWORK == ret) {
146 vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), VCD_ERROR_TIMED_OUT, "voice_framework.error.engine.set_recording_fail");
148 vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), VCD_ERROR_OPERATION_FAILED, "voice_framework.error.engine.set_recording_fail");
153 if (VCE_SPEECH_DETECT_BEGIN == speech_detected) {
154 if (-1 != vcd_client_manager_get_pid()) {
155 /* Manager client is available */
156 if (0 != vcdc_send_speech_detected(vcd_client_manager_get_pid())) {
157 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send speech detected");
160 } else if (VCE_SPEECH_DETECT_END == speech_detected) {
161 if (VCD_RECOGNITION_MODE_STOP_BY_SILENCE == vcd_client_get_recognition_mode()) {
162 /* silence detected */
163 ecore_timer_add(0, __stop_by_silence, NULL);
164 } else if (VCD_RECOGNITION_MODE_RESTART_AFTER_REJECT == vcd_client_get_recognition_mode()) {
165 /* Stop engine recognition */
166 int ret = vcd_engine_recognize_stop();
168 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to stop recognition : %d", ret);
170 vcd_config_set_service_state(VCD_STATE_PROCESSING);
171 vcdc_send_service_state(VCD_STATE_PROCESSING);
173 SLOG(LOG_INFO, TAG_VCD, "[Server] Stop engine only by silence");
174 } else if (VCD_RECOGNITION_MODE_RESTART_CONTINUOUSLY == vcd_client_get_recognition_mode()) {
175 /* Stop engine recognition */
176 int ret = vcd_engine_recognize_stop();
178 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to stop recognition : %d", ret);
186 void __server_recorder_interrupt_callback()
188 SLOG(LOG_INFO, TAG_VCD, "@@@ Cancel by sound interrupt");
190 ecore_timer_add(0, __cancel_by_interrupt, NULL);
192 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
195 static void __config_lang_changed_cb(const char* current_lang, void* user_data)
197 SLOG(LOG_INFO, TAG_VCD, "@@@ Change language ");
199 /* Current state is recording */
200 vcd_state_e state = vcd_config_get_service_state();
201 if (VCD_STATE_RECORDING == state || VCD_STATE_PROCESSING == state) {
202 SLOG(LOG_INFO, TAG_VCD, "[Server] Current state is 'Recording'. Cancel recognition");
203 vcd_server_mgr_cancel();
207 ret = vcd_engine_set_current_language(current_lang);
209 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set language of engine : %d", ret);
212 SLOG(LOG_INFO, TAG_VCD, "@@@");
217 static void __config_foreground_changed_cb(int previous, int current, void* user_data)
219 SLOG(LOG_DEBUG, TAG_VCD, "@@@ Change foreground");
221 SLOG(LOG_INFO, TAG_VCD, "Foreground pid(%d)", current);
223 if (VC_NO_FOREGROUND_PID != current) {
224 /* Foreground app is changed */
225 vcd_state_e state = vcd_config_get_service_state();
226 if (VCD_STATE_RECORDING == state) {
227 SLOG(LOG_INFO, TAG_VCD, "[Server] Foreground pid(%d) is changed. Cancel recognition", current);
228 ecore_timer_add(0, __cancel_by_interrupt, NULL);
232 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
237 static int __vcd_activate_app_by_appcontrol(const char* appid)
240 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Invalid parameter");
241 return VCD_ERROR_INVALID_PARAMETER;
245 app_control_h app_control = NULL;
246 ret = app_control_create(&app_control);
247 if (APP_CONTROL_ERROR_NONE == ret) {
249 ret = app_control_add_extra_data(app_control, "voice_launch", "get_result");
250 if (APP_CONTROL_ERROR_NONE != ret) {
251 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to add extra data, ret(%d)", ret);
252 app_control_destroy(app_control);
253 return VCD_ERROR_OPERATION_FAILED;
256 ret = app_control_set_app_id(app_control, appid);
257 if (APP_CONTROL_ERROR_NONE != ret) {
258 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to set app id, ret(%d)", ret);
259 app_control_destroy(app_control);
260 return VCD_ERROR_OPERATION_FAILED;
262 // Sent launch request
263 ret = app_control_send_launch_request(app_control, NULL, NULL);
264 if (APP_CONTROL_ERROR_NONE != ret) {
265 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to send launch request, ret(%d)", ret);
266 app_control_destroy(app_control);
267 return VCD_ERROR_OPERATION_FAILED;
269 // Destroy app control
270 ret = app_control_destroy(app_control);
271 if (APP_CONTROL_ERROR_NONE != ret) {
272 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to destroy, ret(%d)", ret);
273 return VCD_ERROR_OPERATION_FAILED;
276 return VCD_ERROR_NONE;
279 static int __vcd_resume_app(const char* appid)
281 app_context_h app_context = NULL;
282 int ret = app_manager_get_app_context(appid, &app_context);
283 if (APP_MANAGER_ERROR_NONE != ret) {
284 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to get app_context, ret(%d), appid(%s)", ret, appid);
285 return VCD_ERROR_OPERATION_FAILED;
288 ret = app_manager_resume_app(app_context);
289 if (APP_MANAGER_ERROR_NONE != ret) {
290 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to resume app, ret(%d), appid(%s)", ret, appid);
291 return VCD_ERROR_OPERATION_FAILED;
293 return VCD_ERROR_NONE;
296 static bool __vcd_is_package_installed(const char* appid)
298 app_info_h app_info = NULL;
299 int ret = app_manager_get_app_info(appid, &app_info);
300 if (APP_MANAGER_ERROR_NONE != ret || NULL == app_info)
302 ret = app_info_destroy(app_info);
303 if (APP_MANAGER_ERROR_NONE != ret)
304 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to destroy app_info, ret(%d)", ret);
308 void __vc_free_deactivated_app(void* data)
310 vc_deactivated_app_s* d_app = (vc_deactivated_app_s*)data;
313 if (NULL != d_app->appid) {
323 static bool __vcd_launch_app(const char* result)
325 if (NULL == result) {
326 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Invalid parameter");
327 return VCD_ERROR_INVALID_PARAMETER;
330 GSList* app_list = NULL;
331 if (0 != vc_db_get_appid_list(result, &app_list)) {
332 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] result text is NULL");
333 return VCD_ERROR_INVALID_PARAMETER;
336 if (0 != g_slist_length(app_list)) {
339 vc_deactivated_app_s* temp_app = NULL;
340 iter = g_slist_nth(app_list, 0);
342 while (NULL != iter) {
343 temp_app = iter->data;
345 if (NULL != temp_app && NULL != temp_app->appid) {
347 bool running = false;
348 ret = app_manager_is_running(temp_app->appid, &running);
349 if (APP_MANAGER_ERROR_NONE != ret) {
350 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to check running with appid(%s)", temp_app->appid);
351 g_slist_free_full(iter, __vc_free_deactivated_app);
352 return VCD_ERROR_OPERATION_FAILED;
354 if (false == running) {
355 int tmp_ret = __vcd_is_package_installed(temp_app->appid);
356 if (false == tmp_ret) {
357 SLOG(LOG_WARN, TAG_VCD, "[WARNING] app is not installed, appid(%s)", temp_app->appid);
359 ret = __vcd_activate_app_by_appcontrol(temp_app->appid);
361 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to activate app");
362 g_slist_free_full(iter, __vc_free_deactivated_app);
365 SLOG(LOG_ERROR, TAG_VCD, "Launch app: appid(%s) result(%s)", temp_app->appid, result);
368 ret = __vcd_resume_app(temp_app->appid);
370 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to resume app");
371 g_slist_free_full(iter, __vc_free_deactivated_app);
374 SLOG(LOG_ERROR, TAG_VCD, "Resume app: appid(%s) result(%s)", temp_app->appid, result);
376 __vc_free_deactivated_app((void*)temp_app);
379 app_list = g_slist_remove_link(app_list, iter);
381 iter = g_slist_nth(app_list, 0);
386 return VCD_ERROR_NONE;
389 static Eina_Bool __vcd_send_selected_result(void *data)
391 GSList* pid_list = NULL;
392 const char* result = vcd_client_manager_get_result_text();
394 if (0 != vc_info_parser_get_result_pid_list(&pid_list, result)) {
395 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to get pid list. No result");
397 if (0 < g_slist_length(pid_list)) {
399 vc_cmd_s* temp_cmd = NULL;
404 iter = g_slist_nth(pid_list, 0);
405 while (NULL != iter) {
406 temp_cmd = iter->data;
408 if (NULL != temp_cmd && (pre_pid != temp_cmd->pid || pre_type == VC_COMMAND_TYPE_WIDGET || temp_cmd->type == VC_COMMAND_TYPE_WIDGET)) {
409 /* Launch deactivated several apps that is matched with result */
410 ret = __vcd_launch_app(result);
412 SLOG(LOG_ERROR, TAG_VCD, "Fail to launch or resume app, ret(%d) result(%s)", ret, result);
414 /* send result noti */
415 ret = vcdc_send_result(temp_cmd->pid, vcd_client_manager_get_pid(), temp_cmd->type);
417 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result, ret(%d)", ret);
418 g_slist_free_full(pid_list, free);
422 SLOG(LOG_ERROR, TAG_VCD, "[Server] Send result : pid(%d) type(%d)", temp_cmd->pid, temp_cmd->type);
423 pre_pid = temp_cmd->pid;
424 pre_type = temp_cmd->type;
430 pid_list = g_slist_remove_link(pid_list, iter);
432 iter = g_slist_nth(pid_list, 0);
437 if (VCD_RECOGNITION_MODE_RESTART_CONTINUOUSLY != vcd_client_get_recognition_mode()) {
438 vcd_config_set_service_state(VCD_STATE_READY);
439 vcdc_send_service_state(VCD_STATE_READY);
445 int vcd_send_asr_result(vce_asr_result_event_e event, const char* asr_result, void *user_data)
447 int ret = __vcd_server_launch_manager_app();
449 SECURE_SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send ASR result : mgr_pid(%d), asr_result(%s)", vcd_client_manager_get_pid(), asr_result);
453 if (NULL != asr_result) {
454 SECURE_SLOG(LOG_INFO, TAG_VCD, "[Server] ASR result - Event(%d), Text(%s)", event, asr_result);
455 ret = vcdc_send_pre_result_to_manager(vcd_client_manager_get_pid(), event, asr_result);
457 SECURE_SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send ASR result : mgr_pid(%d), asr_result(%s)", vcd_client_manager_get_pid(), asr_result);
464 int vcd_send_specific_engine_result(const char* engine_app_id, const char* event, const char* result, void *user_info)
466 if (NULL != result) {
467 SLOG(LOG_INFO, TAG_VCD, "[Server] specific engine result - Event(%s), Text(%s)", event, result);
468 vcdc_send_specific_engine_result_to_manager(vcd_client_manager_get_pid(), engine_app_id, event, result);
471 return VCD_ERROR_NONE;
474 int vcd_send_nlg_result(const char* nlg_result, void *user_data)
476 int ret = __vcd_server_launch_manager_app();
478 SECURE_SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send dialog : mgr_pid(%d), nlg_result(%s)", vcd_client_manager_get_pid(), nlg_result);
482 SLOG(LOG_ERROR, TAG_VCD, "[Server] send dialog : mgr_pid(%d), nlg_result(%s)", vcd_client_manager_get_pid(), nlg_result);
483 ret = vcdc_send_dialog(vcd_client_manager_get_pid(), -1, nlg_result, NULL, 0); //0: VC_DIALOG_END
485 SECURE_SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send dialog : mgr_pid(%d), nlg_result(%s)", vcd_client_manager_get_pid(), nlg_result);
489 static void* __recorder_stop(void *data)
495 int vcd_send_result(vce_result_event_e event, int* result_id, int count, const char* all_result, const char* non_fixed_result, const char* nlu_result, const char* msg, int* user_info, void *user_data)
498 vcd_recognition_mode_e recognition_mode = vcd_client_get_recognition_mode();
500 if (VCD_STATE_PROCESSING != vcd_config_get_service_state()) {
501 if (VCD_RECOGNITION_MODE_RESTART_CONTINUOUSLY != recognition_mode) {
502 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not 'Processing' and mode is not 'Restart continuously'");
503 return VCD_ERROR_INVALID_STATE;
507 vc_info_parser_unset_result(vcd_client_manager_get_exclusive());
508 vcd_client_manager_set_result_text(all_result);
510 SECURE_SLOG(LOG_INFO, TAG_VCD, "[Server] Event(%d), Text(%s) Nonfixed(%s) Msg(%s) Result count(%d)",
511 event, all_result, non_fixed_result, msg, count);
513 SECURE_SLOG(LOG_ERROR, TAG_VCD, "[Server] NLU result(%s)", nlu_result);
516 /* if nlu_result is exist, Add command handle(is_action) into result list */
518 SLOG(LOG_INFO, TAG_VCD, "[Server] @ Get engine result @");
520 vc_cmd_s* temp_cmd = NULL;
521 vc_cmd_list_h vc_cmd_list = NULL;
523 if (0 != vc_cmd_list_create(&vc_cmd_list)) {
524 SLOG(LOG_INFO, TAG_VCD, "[Server] Fail to create command list");
525 vcd_client_manager_set_exclusive(false);
526 vcd_config_set_service_state(VCD_STATE_READY);
527 vcdc_send_service_state(VCD_STATE_READY);
528 return VCD_ERROR_NONE;
531 /* priority filter */
532 /* system > exclusive > widget > foreground > system_background > widget partial > foreground partial > background */
534 int* filtered_id = (int*)calloc(count, sizeof(int));
536 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to allocate memory");
537 vc_cmd_list_destroy(vc_cmd_list, true);
539 return VCD_ERROR_OUT_OF_MEMORY;
541 int filtered_count = 0;
542 int top_priority = VC_COMMAND_PRIORITY_BACKGROUND;
543 for (i = 0; i < count; i++) {
544 SLOG(LOG_INFO, TAG_VCD, "[Server] [%d] Result id(%d)", i, result_id[i]);
546 if (0 > result_id[i]) {
547 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Result ID(%d) is NOT valid", result_id[i]);
551 ret = vcd_client_get_cmd_from_result_id(result_id[i], &temp_cmd);
552 if (0 == ret && NULL != temp_cmd) {
553 if (top_priority == temp_cmd->priority) {
554 filtered_id[filtered_count] = result_id[i];
556 } else if (top_priority > temp_cmd->priority) {
557 filtered_id[0] = result_id[i];
559 top_priority = temp_cmd->priority;
562 vc_cmd_destroy((vc_cmd_h)temp_cmd);
567 if (top_priority >= VC_COMMAND_PRIORITY_WIDGET) {
568 int pid = vcd_client_widget_get_foreground_pid();
570 if (NULL != all_result) {
571 vc_info_parser_set_result(all_result, event, msg, NULL, false);
573 vcd_client_widget_get_asr_result_enabled(pid, &enable);
574 if (true == enable) {
575 SLOG(LOG_INFO, TAG_VCD, "[Server] Send ASR result to Widget client");
576 bool is_consumed = false;
577 if (NULL != user_info) {
580 if (0 != vcdc_send_asr_result(pid, event, all_result, VC_COMMAND_TYPE_WIDGET, &is_consumed)) {
581 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send asr result");
583 SLOG(LOG_INFO, TAG_VCD, "[Server] ASR result is consumed(%d)", is_consumed);
584 if (true == is_consumed) {
585 if (NULL != user_info) {
587 SLOG(LOG_ERROR, TAG_VCD, "[Server] Send whether ASR result is consumed or not (%d)", *user_info);
589 vcdc_send_show_tooltip(pid, false);
590 if (-1 != vcd_client_manager_get_pid()) {
591 /* Manager client is available */
592 vc_info_parser_unset_result(false);
593 vc_info_parser_set_result(all_result, VC_RESULT_EVENT_RESULT_SUCCESS, msg, NULL, false);
594 if (0 != vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NOTIFICATION)) {
595 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
599 // Set state manually, because the result is already handled in ASR result by client.
600 // So, the daemon does not need to send the result to client.
601 vcd_client_manager_set_exclusive(false);
603 vcd_config_set_service_state(VCD_STATE_READY);
604 vcdc_send_service_state(VCD_STATE_READY);
605 vc_cmd_list_destroy(vc_cmd_list, true);
607 if (NULL != filtered_id) {
611 return VCD_ERROR_NONE;
620 for (i = 0; i < filtered_count; i++) {
621 SLOG(LOG_INFO, TAG_VCD, "[Server] [%d] Filtered Result id(%d)", i, filtered_id[i]);
623 if (filtered_id[i] < 0) {
624 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Filtered ID(%d) is NOT valid", filtered_id[i]);
628 ret = vcd_client_get_cmd_from_result_id(filtered_id[i], &temp_cmd);
629 if (0 == ret && NULL != temp_cmd) {
630 switch (temp_cmd->format) {
631 case VC_CMD_FORMAT_FIXED:
632 case VC_CMD_FORMAT_FIXED_AND_VFIXED:
633 case VC_CMD_FORMAT_VFIXED_AND_FIXED:
634 case VC_CMD_FORMAT_PARTIAL:
635 case VC_CMD_FORMAT_FIXED_AND_NONFIXED:
636 case VC_CMD_FORMAT_NONFIXED_AND_FIXED:
638 case VC_CMD_FORMAT_ACTION:
642 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Unknown command type : %d", temp_cmd->type);
646 if (0 != vc_cmd_list_add(vc_cmd_list, (vc_cmd_h)temp_cmd)) {
647 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to add command to list");
648 vc_cmd_destroy((vc_cmd_h)temp_cmd);
652 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] NOT found matched result(%d)", filtered_id[i]);
656 if (NULL != filtered_id) {
661 if (NULL != nlu_result) {
662 SECURE_SLOG(LOG_INFO, TAG_VCD, "[Server] NLU (%s)", nlu_result);
663 vc_info_parser_set_nlu_result(nlu_result);
664 if (0 == is_action) {
666 if (0 != vc_cmd_create(&nlu_cmd)) {
667 SLOG(LOG_ERROR, TAG_VCD, "Fail to nlu cmd create");
669 if (0 != vc_cmd_set_type(nlu_cmd, VC_COMMAND_TYPE_SYSTEM)) {
670 SLOG(LOG_ERROR, TAG_VCD, "Fail to set type");
672 if (0 != vc_cmd_set_pid(nlu_cmd, vcd_client_manager_get_pid())) {
673 SLOG(LOG_ERROR, TAG_VCD, "Fail to set pid");
675 if (0 != vc_cmd_set_format(nlu_cmd, VC_CMD_FORMAT_ACTION)) {
676 SLOG(LOG_ERROR, TAG_VCD, "Fail to set format");
678 if (0 != vc_cmd_list_add(vc_cmd_list, nlu_cmd)) {
679 SLOG(LOG_ERROR, TAG_VCD, "Fail to add nlu cmd to list");
680 vc_cmd_destroy(nlu_cmd);
686 vc_cmd_print_list(vc_cmd_list);
688 SLOG(LOG_INFO, TAG_VCD, "[Server] @@@@");
690 int result_count = 0;
691 vc_cmd_list_get_count(vc_cmd_list, &result_count);
693 /* Handle the result list */
694 if (0 == result_count) {
696 vc_cmd_list_h widget_cmd_list = NULL;
697 vc_cmd_list_h foreground_cmd_list = NULL;
698 if (NULL != all_result) {
699 SECURE_SLOG(LOG_INFO, TAG_VCD, "[Server] Engine result is no command : %s", all_result);
702 if (0 != vc_cmd_list_create(&widget_cmd_list)) {
703 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to create widget command list handle");
704 vc_cmd_list_destroy(vc_cmd_list, true);
706 return VCD_ERROR_OUT_OF_MEMORY;
709 /* Get the list of widget type commands */
710 vcd_client_append_cmd_from_type(VC_COMMAND_TYPE_WIDGET, widget_cmd_list);
711 vc_cmd_list_get_count(widget_cmd_list, &cnt);
713 /* Matched with widget command partially */
714 vc_cmd_get_partially_matched_cmd_list(all_result, widget_cmd_list, vc_cmd_list, VC_SEARCH_NONE_LEVEL);
715 vc_cmd_list_get_count(vc_cmd_list, &cnt);
717 top_priority = VC_COMMAND_PRIORITY_WIDGET;
718 SLOG(LOG_INFO, TAG_VCD, "[INFO] Partially matched widget command");
721 if (0 != vc_cmd_list_create(&foreground_cmd_list)) {
722 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to create foreground command list handle");
723 vc_cmd_list_destroy(vc_cmd_list, true);
725 vc_cmd_list_destroy(widget_cmd_list, true);
726 widget_cmd_list = NULL;
727 return VCD_ERROR_OUT_OF_MEMORY;
730 /* Get the list of foreground type commands */
731 vcd_client_append_cmd_from_type(VC_COMMAND_TYPE_FOREGROUND, foreground_cmd_list);
732 vc_cmd_list_get_count(foreground_cmd_list, &cnt);
734 /* Matched with foreground command partially */
735 vc_cmd_get_partially_matched_cmd_list(all_result, foreground_cmd_list, vc_cmd_list, VC_SEARCH_NONE_LEVEL);
736 vc_cmd_list_get_count(vc_cmd_list, &cnt);
738 top_priority = VC_COMMAND_PRIORITY_FOREGROUND;
739 SLOG(LOG_INFO, TAG_VCD, "[INFO] Partially matched foreground command");
742 vc_cmd_list_destroy(foreground_cmd_list, true);
743 foreground_cmd_list = NULL;
745 vc_cmd_list_destroy(widget_cmd_list, true);
746 widget_cmd_list = NULL;
748 SLOG(LOG_INFO, TAG_VCD, "[Server] Engine all result is NULL");
751 vc_cmd_list_get_count(vc_cmd_list, &result_count);
753 // After running partial matching algorithm, if there is no result.
754 if (0 == result_count) {
755 SLOG(LOG_INFO, TAG_VCD, "[Server] No commands even after partial matching");
757 bool temp = vcd_client_manager_get_exclusive();
758 vc_info_parser_set_result(all_result, event, msg, NULL, temp);
760 int pid = vcd_client_widget_get_foreground_pid();
762 SLOG(LOG_INFO, TAG_VCD, "[Server] Request tooltip hide");
763 /* Send to hide tooltip */
764 vcdc_send_show_tooltip(pid, false);
767 if (-1 != vcd_client_manager_get_pid()) {
768 /* Manager client is available */
769 if (0 != vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NORMAL)) {
770 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
774 /* set service state ready */
775 vcd_config_set_service_state(VCD_STATE_READY);
776 vcdc_send_service_state(VCD_STATE_READY);
778 vcd_client_manager_set_exclusive(false);
779 vc_cmd_list_destroy(vc_cmd_list, true);
782 return VCD_ERROR_NONE;
785 // Partial matching algorithm find some commands
786 event = VC_RESULT_EVENT_RESULT_SUCCESS;
789 // There are more than one result.
790 if (false == vcd_client_manager_get_exclusive()) {
791 vc_cmd_list_h temp_list = NULL;
793 /* Foreground, Widget, Background, System, System-Background */
794 if (top_priority >= VC_COMMAND_PRIORITY_BACKGROUND) {
795 vc_cmd_list_h widget_cmd_list = NULL;
796 vc_cmd_list_h foreground_cmd_list = NULL;
799 if (0 != vc_cmd_list_create(&temp_list)) {
800 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to create widget command list handle");
801 vc_cmd_list_destroy(vc_cmd_list, true);
803 return VCD_ERROR_OUT_OF_MEMORY;
806 if (0 != vc_cmd_list_create(&widget_cmd_list)) {
807 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to create widget command list handle");
808 vc_cmd_list_destroy(vc_cmd_list, true);
810 vc_cmd_list_destroy(temp_list, true);
812 return VCD_ERROR_OUT_OF_MEMORY;
815 /* Get the list of widget type commands */
816 vcd_client_append_cmd_from_type(VC_COMMAND_TYPE_WIDGET, widget_cmd_list);
817 vc_cmd_list_get_count(widget_cmd_list, &cnt);
819 /* Matched with widget command partially */
820 vc_cmd_get_partially_matched_cmd_list(all_result, widget_cmd_list, temp_list, VC_SEARCH_NONE_LEVEL);
821 vc_cmd_list_get_count(temp_list, &cnt);
823 if (0 != vc_cmd_list_destroy(vc_cmd_list, true)) {
824 SLOG(LOG_WARN, TAG_VCD, "[WARNING] Fail to destroy list");
826 vc_cmd_list = temp_list;
827 top_priority = VC_COMMAND_PRIORITY_WIDGET;
828 event = VC_RESULT_EVENT_RESULT_SUCCESS;
829 SLOG(LOG_INFO, TAG_VCD, "[INFO] Partially matched widget command when background cmd exists");
832 if (0 != vc_cmd_list_create(&foreground_cmd_list)) {
833 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to create foreground command list handle");
834 vc_cmd_list_destroy(vc_cmd_list, true);
836 vc_cmd_list_destroy(widget_cmd_list, true);
837 widget_cmd_list = NULL;
838 return VCD_ERROR_OUT_OF_MEMORY;
841 /* Get the list of foreground type commands */
842 vcd_client_append_cmd_from_type(VC_COMMAND_TYPE_FOREGROUND, foreground_cmd_list);
843 vc_cmd_list_get_count(foreground_cmd_list, &cnt);
845 /* Matched with foreground command partially */
846 vc_cmd_get_partially_matched_cmd_list(all_result, foreground_cmd_list, temp_list, VC_SEARCH_NONE_LEVEL);
847 vc_cmd_list_get_count(temp_list, &cnt);
849 if (0 != vc_cmd_list_destroy(vc_cmd_list, true)) {
850 SLOG(LOG_WARN, TAG_VCD, "[WARNING] Fail to destroy list");
852 vc_cmd_list = temp_list;
853 top_priority = VC_COMMAND_PRIORITY_FOREGROUND;
854 event = VC_RESULT_EVENT_RESULT_SUCCESS;
855 SLOG(LOG_INFO, TAG_VCD, "[INFO] Partially matched foreground command when background cmd exists");
858 vc_cmd_list_destroy(foreground_cmd_list, true);
859 foreground_cmd_list = NULL;
861 vc_cmd_list_destroy(widget_cmd_list, true);
862 widget_cmd_list = NULL;
865 int pid = vcd_client_widget_get_foreground_pid();
867 SLOG(LOG_INFO, TAG_VCD, "[Server] Request tooltip hide");
868 vcdc_send_show_tooltip(pid, false);
871 vc_info_parser_set_result(all_result, event, msg, vc_cmd_list, false);
872 vc_cmd_list_destroy(vc_cmd_list, true);
875 if (-1 != vcd_client_manager_get_pid()) {
876 /* Manager client is available */
877 if (0 != vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NORMAL)) {
878 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
881 SLOG(LOG_INFO, TAG_VCD, "[Server] Manager is NOT available. Send result to client directly");
882 ecore_timer_add(0, __vcd_send_selected_result, NULL);
885 /* exclusive command */
886 vc_info_parser_set_result(all_result, event, msg, vc_cmd_list, true);
887 vc_cmd_list_destroy(vc_cmd_list, true);
890 if (-1 != vcd_client_manager_get_pid()) {
891 /* Manager client is available */
892 if (0 != vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NORMAL)) {
893 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
896 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Manager is NOT available");
899 vcd_client_manager_set_exclusive(false);
902 if (VCD_RECOGNITION_MODE_RESTART_AFTER_REJECT == recognition_mode) {
903 if (VCE_RESULT_EVENT_REJECTED == event) {
904 SLOG(LOG_INFO, TAG_VCD, "[Server] Restart by no or rejected result");
905 /* If no result and restart option is ON */
906 /* Send reject message */
907 bool temp = vcd_client_manager_get_exclusive();
908 vc_info_parser_set_result(all_result, event, msg, NULL, temp);
909 ret = vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NOTIFICATION);
911 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
914 g_restart_timer = ecore_timer_add(0, __restart_engine, NULL);
917 SLOG(LOG_INFO, TAG_VCD, "[Server] Stop recorder due to success");
918 //vcd_recorder_stop();
919 ecore_main_loop_thread_safe_call_sync(__recorder_stop, NULL);
920 } else if (VCD_RECOGNITION_MODE_RESTART_CONTINUOUSLY == recognition_mode) {
921 SLOG(LOG_INFO, TAG_VCD, "[Server] Restart continuously");
922 /* Restart option is ON */
923 g_restart_timer = ecore_timer_add(0, __restart_engine, NULL);
924 if (VCE_RESULT_EVENT_REJECTED == event) {
925 bool temp = vcd_client_manager_get_exclusive();
926 vc_info_parser_set_result(all_result, event, msg, NULL, temp);
927 ret = vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NOTIFICATION);
929 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
935 return VCD_ERROR_NONE;
939 if (NULL == result_id) {
941 if (NULL != all_result) {
942 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Engine result is no command : %s", all_result);
943 bool temp = vcd_client_manager_get_exclusive();
944 vc_info_parser_set_result(all_result, event, msg, NULL, temp);
947 int pid = vcd_client_widget_get_foreground_pid();
949 if (NULL != all_result) {
950 /* Send result text to widget */
951 vcdc_send_result(pid, vcd_client_manager_get_pid(), VC_COMMAND_TYPE_WIDGET);
954 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Request tooltip hide");
955 /* Send to hide tooltip */
956 vcdc_send_show_tooltip(pid, false);
959 if (-1 != vcd_client_manager_get_pid()) {
960 /* Manager client is available */
961 if (0 != vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NORMAL)) {
962 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
966 vcd_client_manager_set_exclusive(false);
972 SLOG(LOG_DEBUG, TAG_VCD, "[Server] @ Get engine result @");
975 vc_cmd_s* temp_cmd = NULL;
976 vc_cmd_list_h vc_cmd_list = NULL;
978 if (0 != vc_cmd_list_create(&vc_cmd_list)) {
979 SLOG(LOG_ERROR, TAG_VCD, "[Server] Fail to create command list");
980 vcd_client_manager_set_exclusive(false);
981 vcd_config_set_service_state(VCD_STATE_READY);
982 vcdc_send_service_state(VCD_STATE_READY);
987 for (i = 0; i < count; i++) {
988 SLOG(LOG_DEBUG, TAG_VCD, "[Server] [%d] Result ID(%d)", i, result_id[i]);
990 if (result_id[i] < 0) {
991 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Result ID(%d) is NOT valid", result_id[i]);
995 ret = vcd_client_get_cmd_from_result_id(result_id[i], &temp_cmd);
996 if (0 == ret && NULL != temp_cmd) {
997 switch (temp_cmd->format) {
998 case VC_CMD_FORMAT_FIXED:
999 case VC_CMD_FORMAT_FIXED_AND_VFIXED:
1000 case VC_CMD_FORMAT_VFIXED_AND_FIXED:
1001 case VC_CMD_FORMAT_PARTIAL:
1002 /* Nonfixed result is NOT valid */
1004 case VC_CMD_FORMAT_FIXED_AND_NONFIXED:
1005 if (NULL == temp_cmd->parameter) {
1006 if (NULL != non_fixed_result) {
1007 temp_cmd->parameter = strdup(non_fixed_result);
1010 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Command type is NOT valid. Parameter (%s)", temp_cmd->parameter);
1013 case VC_CMD_FORMAT_NONFIXED_AND_FIXED:
1014 if (NULL == temp_cmd->command) {
1015 if (NULL != non_fixed_result) {
1016 temp_cmd->command = strdup(non_fixed_result);
1019 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Command type is NOT valid. Command (%s)", temp_cmd->command);
1024 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Unknown command type : %d", temp_cmd->type);
1028 if (0 != vc_cmd_list_add(vc_cmd_list, (vc_cmd_h)temp_cmd)) {
1029 SLOG(LOG_DEBUG, TAG_VCD, "Fail to add command to list");
1030 vc_cmd_destroy((vc_cmd_h)temp_cmd);
1033 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] NOT found matched result(%d)", result_id[i]);
1037 vc_cmd_print_list(vc_cmd_list);
1039 SLOG(LOG_DEBUG, TAG_VCD, "[Server] @@@@");
1041 int result_count = 0;
1042 vc_cmd_list_get_count(vc_cmd_list, &result_count);
1044 if (false == vcd_client_manager_get_exclusive()) {
1045 int pid = vcd_client_widget_get_foreground_pid();
1047 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Request tooltip hide");
1048 vcdc_send_show_tooltip(pid, false);
1051 vc_info_parser_set_result(all_result, event, msg, vc_cmd_list, false);
1053 if (-1 != vcd_client_manager_get_pid()) {
1054 /* Manager client is available */
1055 if (0 != vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NORMAL)) {
1056 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
1059 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Manager is NOT available. Send result to client directly");
1060 /* Send result to client */
1061 ecore_timer_add(0, __vcd_send_selected_result, NULL);
1064 /* exclusive command */
1065 vc_info_parser_set_result(all_result, event, msg, vc_cmd_list, true);
1067 if (-1 != vcd_client_manager_get_pid()) {
1068 /* Manager client is available */
1069 if (0 != vcdc_send_result_to_manager(vcd_client_manager_get_pid(), VC_RESULT_TYPE_NORMAL)) {
1070 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send result");
1073 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Manager is NOT available");
1076 vcd_client_manager_set_exclusive(false);
1079 vc_cmd_list_destroy(vc_cmd_list, true);
1087 static void __vcd_server_nlu_result_cb(vce_result_event_e event, const char* nlu_result, void *user_data)
1089 SECURE_SLOG(LOG_DEBUG, TAG_VCD, "[Server] NLU result cb - event(%d)", event);
1090 SECURE_SLOG(LOG_DEBUG, TAG_VCD, "[Server] result (%s)", nlu_result);
1092 int ret = vc_info_parser_set_nlu_result(nlu_result);
1094 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set nlu result (%d)", ret);
1101 int vcd_send_error(vce_error_e error, const char* msg, void *user_data)
1103 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Engine Error cb - reason(%d), msg(%s)", error, msg);
1104 ecore_main_loop_thread_safe_call_async(__cancel_by_error, NULL);
1106 char* error_msg = NULL;
1108 error_msg = strdup(msg);
1109 if (NULL == error_msg) {
1110 return VCD_ERROR_OUT_OF_MEMORY;
1114 int ret = VCD_ERROR_NONE;
1115 ret = vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), error, error_msg);
1116 if (VCD_ERROR_NONE != ret) {
1117 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send error signal");
1120 if (NULL != error_msg) {
1128 /* for TTS feedback */
1129 int vcd_send_feedback_audio_format(int rate, vce_audio_channel_e channel, vce_audio_type_e audio_type)
1131 SLOG(LOG_INFO, TAG_VCD, "[Server DEBUG] Engine - Send TTS feedback audio format, g_current_uid(%d)", g_current_uid);
1133 /* send TTS feedback audio format to VC manager */
1134 int ret = VCD_ERROR_NONE;
1135 int pid = g_current_uid / 1000;
1136 if (-1 == g_current_uid || vcd_client_manager_get_pid() == pid) {
1137 ret = vcdc_send_feedback_audio_format_to_manager(vcd_client_manager_get_pid(), rate, channel, audio_type);
1138 if (VCD_ERROR_NONE != ret) {
1139 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send TTS feedback audio format to VC manager");
1142 SLOG(LOG_INFO, TAG_VCD, "[Server INFO] Do not send TTS feedback audio format to VC manager");
1148 int vcd_send_feedback_streaming(vce_feedback_event_e event, char* buffer, int len)
1150 if (-1 == g_current_uid && VCE_FEEDBACK_EVENT_START == event) {
1151 g_current_utt_id = (g_current_utt_id + 1) % 1000;
1152 g_current_uid = vcd_client_manager_get_pid() * 1000 + g_current_utt_id;
1153 SLOG(LOG_INFO, TAG_VCD, "[Server info] set current uid and utt_id as manager pid(%d)", vcd_client_manager_get_pid());
1156 int ret = VCD_ERROR_NONE;
1157 int pid = g_current_uid / 1000;
1158 int utt_id = g_current_uid % 1000;
1160 SLOG(LOG_INFO, TAG_VCD, "[Server DEBUG] Engine - Send TTS feedback streaming event(%d), uid(%d), is_mgr_client(%d)", event, g_current_uid, (pid == vcd_client_manager_get_pid() ? true : false));
1162 if (pid == vcd_client_manager_get_pid()) {
1163 /* send TTS feedback streaming to manager client */
1164 ret = vcdc_send_feedback_streaming_to_manager(vcd_client_manager_get_pid(), pid, utt_id, event, buffer, len);
1165 if (VCD_ERROR_NONE != ret) {
1166 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send TTS feedback streaming to manager client");
1169 /* send TTS feedback streaming to client */
1170 ret = vcdc_send_feedback_streaming(pid, utt_id, event, buffer, len);
1171 if (VCD_ERROR_NONE != ret) {
1172 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send TTS feedback streaming to client");
1176 if (VCE_FEEDBACK_EVENT_FINISH == event) {
1177 /* reset current uid */
1180 /* Set service state to ready if state is synthesizing */
1181 vcd_state_e state = vcd_config_get_service_state();
1182 if (VCD_STATE_SYNTHESIZING == state) {
1183 vcd_config_set_service_state(VCD_STATE_READY);
1185 SLOG(LOG_INFO, TAG_VCD, "[Server info] feedback streaming finish event, reset current uid & service state(%d)", vcd_config_get_service_state());
1192 * vcd server Interfaces
1194 static void __vcd_file_clean_up()
1196 SLOG(LOG_INFO, TAG_VCD, "== Old file clean up == ");
1199 struct dirent *dirp = NULL;
1201 dp = opendir(VC_RUNTIME_INFO_ROOT);
1203 SLOG(LOG_ERROR, TAG_VCD, "[File message WARN] Fail to open path : %s", VC_RUNTIME_INFO_ROOT);
1207 char remove_path[257] = {0, };
1212 if (!strncmp("vc_", dirp->d_name, strlen("vc_"))) {
1213 memset(remove_path, 0, 257);
1214 snprintf(remove_path, 257, "%s/%s", VC_RUNTIME_INFO_ROOT, dirp->d_name);
1217 if (0 != remove(remove_path)) {
1218 SLOG(LOG_WARN, TAG_VCD, "[File message WARN] Fail to remove file : %s", remove_path);
1220 SLOG(LOG_INFO, TAG_VCD, "[File message] Remove file : %s", remove_path);
1224 } while (NULL != dirp);
1231 static int __vcd_db_clean_up()
1234 int cnt = VC_COMMAND_TYPE_FOREGROUND;
1236 if (VC_COMMAND_TYPE_BACKGROUND != cnt)
1237 ret = vc_db_delete_commands(-1, cnt, NULL);
1238 } while (VC_COMMAND_TYPE_EXCLUSIVE >= ++cnt);
1244 static bool __is_default_engine()
1246 char* engine = NULL;
1247 engine = vconf_get_str(VCONFKEY_VC_ENGINE_DEFAULT);
1248 if (NULL == engine) {
1249 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get sting for vc engine");
1253 char appid[1024] = {'\0', };
1254 if (0 != aul_app_get_appid_bypid(getpid(), appid, sizeof(appid) - 1)) {
1255 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get callee appid by pid");
1258 SLOG(LOG_DEBUG, TAG_VCD, "[Server] VC Default Engine(%s), appId(%s)", engine, appid);
1259 if (0 == strncmp(engine, appid, strlen(engine))) {
1268 int vcd_initialize(vce_request_callback_s *callback)
1272 /* Remove old file */
1273 __vcd_file_clean_up();
1275 /* initialize modules */
1276 ret = vcd_config_initialize(__config_lang_changed_cb, __config_foreground_changed_cb, NULL);
1278 SLOG(LOG_ERROR, TAG_VCD, "[Server WARNING] Fail to initialize config.");
1281 ret = vc_db_initialize_for_daemon();
1283 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to initialize DB : %d", ret);
1287 /* Remove db data */
1288 ret = __vcd_db_clean_up();
1290 SLOG(LOG_ERROR, TAG_VCD, "[Server WARNING] Fail to remove db data");
1293 vcd_config_set_service_state(VCD_STATE_NONE);
1295 ret = vcd_engine_agent_init();
1297 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to engine agent initialize : result(%d)", ret);
1301 if (0 != vcd_recorder_create(__server_recorder_callback, __server_recorder_interrupt_callback)) {
1302 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to create recorder");
1303 return VCD_ERROR_OPERATION_FAILED;
1307 if (0 != vcd_engine_agent_load_current_engine(callback)) {
1308 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to load current engine");
1309 return VCD_ERROR_OPERATION_FAILED;
1312 /* Initialize manager info */
1313 vcd_client_manager_unset();
1315 // if (TRUE == __is_default_engine()) {
1316 /* Open dbus connection */
1317 if (0 != vcd_dbus_open_connection()) {
1318 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to open connection");
1319 return VCD_ERROR_OPERATION_FAILED;
1323 vcd_config_set_service_state(VCD_STATE_READY);
1324 // vcdc_send_service_state(VCD_STATE_READY);
1326 /* Set timer cleanup client all */
1327 g_check_client_timer = ecore_timer_add(CLIENT_CLEAN_UP_TIME, vcd_cleanup_client_all, NULL);
1328 if (NULL == g_check_client_timer) {
1329 SLOG(LOG_WARN, TAG_VCD, "[Server Warning] Fail to create timer of client check");
1333 g_current_utt_id = -1;
1335 SLOG(LOG_ERROR, TAG_VCD, "[Server SUCCESS] initialize");
1343 if (0 < g_list_length(g_proc_list)) {
1344 iter = g_list_first(g_proc_list);
1345 while (NULL != iter) {
1346 g_proc_list = g_list_remove_link(g_proc_list, iter);
1347 iter = g_list_first(g_proc_list);
1351 if (NULL != g_restart_timer) {
1352 ecore_timer_del(g_restart_timer);
1353 g_restart_timer = NULL;
1356 if (NULL != g_check_client_timer) {
1357 ecore_timer_del(g_check_client_timer);
1358 g_check_client_timer = NULL;
1361 vcd_state_e state = vcd_config_get_service_state();
1362 if (VCD_STATE_READY != state) {
1363 if (VCD_STATE_RECORDING == state) {
1364 vcd_recorder_stop();
1366 vcd_engine_recognize_cancel();
1369 if (0 != vcd_recorder_destroy()) {
1370 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to destroy recorder");
1373 SLOG(LOG_DEBUG, TAG_VCD, "[Server] destroy recorder");
1376 if (0 != vcd_engine_agent_release()) {
1377 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to release engine");
1380 SLOG(LOG_DEBUG, TAG_VCD, "[Server] release engine");
1383 vcd_client_manager_unset_appid();
1385 int ret = vcd_config_finalize();
1387 SLOG(LOG_ERROR, TAG_VCD, "[Server WARNING] Fail to finalize config.");
1390 ret = vc_db_finalize();
1392 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to finalize DB : %d", ret);
1395 vcd_config_set_service_state(VCD_STATE_NONE);
1396 vcdc_send_service_state(VCD_STATE_NONE);
1398 /* Open dbus connection */
1399 if (0 != vcd_dbus_close_connection()) {
1400 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to close connection");
1403 SLOG(LOG_ERROR, TAG_VCD, "[Server] mode finalize");
1408 static Eina_Bool __finalize_quit_ecore_loop(void *data)
1410 bool ret = vcd_finalize();
1414 ecore_main_loop_quit();
1419 static void __read_proc()
1422 struct dirent *dirp = NULL;
1426 if (0 < g_list_length(g_proc_list)) {
1427 iter = g_list_first(g_proc_list);
1428 while (NULL != iter) {
1429 g_proc_list = g_list_remove_link(g_proc_list, iter);
1430 iter = g_list_first(g_proc_list);
1434 dp = opendir("/proc");
1436 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to open proc");
1442 tmp = atoi(dirp->d_name);
1443 if (0 >= tmp) continue;
1444 g_proc_list = g_list_append(g_proc_list, GINT_TO_POINTER(tmp));
1446 } while (NULL != dirp);
1452 static void __vcd_cleanup_client(vcd_client_type_e type)
1454 int* client_list = NULL;
1455 int client_count = 0;
1462 if (VCD_CLIENT_TYPE_NORMAL == type) {
1463 ret = vcd_client_get_list(&client_list, &client_count);
1464 } else if (VCD_CLIENT_TYPE_WIDGET == type) {
1465 ret = vcd_client_widget_get_list(&client_list, &client_count);
1466 } else if (VCD_CLIENT_TYPE_MANAGER == type) {
1467 mgr_pid = vcd_client_manager_get_pid();
1468 client_list = &mgr_pid;
1470 if (-1 == mgr_pid) {
1471 SLOG(LOG_WARN, TAG_VCD, "[WARNING] Invalid Manager pid");
1476 if (0 == ret || mgr_pid > 0) {
1477 SLOG(LOG_INFO, TAG_VCD, "@@@ Clean up %s client ", type ? (type == 1) ? "Widget" : "Manager" : "Normal");
1478 if (NULL != client_list && client_count > 0) {
1479 for (i = 0; i < client_count; i++) {
1482 for (j = 0; j < g_list_length(g_proc_list); j++) {
1483 iter = g_list_nth(g_proc_list, j);
1485 if (*(client_list + i) == GPOINTER_TO_INT(iter->data)) {
1486 SLOG(LOG_INFO, TAG_VCD, "%s pid(%d) is running", type ? (type == 1) ? "Widget" : "Manager" : "Normal", *(client_list + i));
1493 if (false == exist) {
1494 SLOG(LOG_ERROR, TAG_VCD, "%s pid(%d) should be removed", type ? (type == 1) ? "Widget" : "Manager" : "Normal", *(client_list + i));
1495 if (VCD_CLIENT_TYPE_NORMAL == type)
1496 vcd_server_finalize(*(client_list + i));
1497 else if (VCD_CLIENT_TYPE_WIDGET == type)
1498 vcd_server_widget_finalize(*(client_list + i));
1500 vcd_server_mgr_finalize(mgr_pid);
1504 SLOG(LOG_INFO, TAG_VCD, "@@@");
1506 if (NULL != client_list && -1 == mgr_pid) {
1513 Eina_Bool vcd_cleanup_client_all(void *data)
1517 __vcd_cleanup_client(VCD_CLIENT_TYPE_NORMAL);
1518 __vcd_cleanup_client(VCD_CLIENT_TYPE_WIDGET);
1519 __vcd_cleanup_client(VCD_CLIENT_TYPE_MANAGER);
1521 if (0 == vcd_client_get_ref_count()) {
1522 SLOG(LOG_INFO, TAG_VCD, "[Server] Connected client list is empty");
1523 ecore_timer_add(0, __finalize_quit_ecore_loop, NULL);
1526 if (0 == vcd_client_get_list(&client_list, &client_count)) {
1527 SLOG(LOG_DEBUG, TAG_VCD, "@@@ Clean up client ");
1528 if (NULL != client_list && client_count > 0) {
1529 for (i = 0; i < client_count; i++) {
1532 for (j = 0; j < g_list_length(g_proc_list); j++) {
1533 iter = g_list_nth(g_proc_list, j);
1535 if (client_list[i] == GPOINTER_TO_INT(iter->data)) {
1536 SLOG(LOG_DEBUG, TAG_VCD, "pid(%d) is running", client_list[i]);
1543 if (false == exist) {
1544 SLOG(LOG_ERROR, TAG_VCD, "pid(%d) should be removed", client_list[i]);
1545 vcd_server_finalize(client_list[i]);
1548 result = vcdc_send_hello(client_list[i], VCD_CLIENT_TYPE_NORMAL);
1551 SLOG(LOG_DEBUG, TAG_VCD, "[Server] pid(%d) should be removed.", client_list[i]);
1552 vcd_server_finalize(client_list[i]);
1553 } else if (-1 == result) {
1554 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Hello result has error");
1559 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
1561 if (NULL != client_list) {
1566 /* If app is in background state, app cannot response message. */
1567 if (0 == vcd_client_widget_get_list(&client_list, &client_count)) {
1568 SLOG(LOG_DEBUG, TAG_VCD, "@@@ Clean up widget");
1569 if (NULL != client_list && client_count > 0) {
1570 for (i = 0; i < client_count; i++) {
1573 for (j = 0; j < g_list_length(g_proc_list); j++) {
1574 iter = g_list_nth(g_proc_list, j);
1576 if (client_list[i] == GPOINTER_TO_INT(iter->data)) {
1577 SLOG(LOG_DEBUG, TAG_VCD, "widget pid(%d) is running", client_list[i]);
1584 if (false == exist) {
1585 SLOG(LOG_ERROR, TAG_VCD, "widget pid(%d) should be removed", client_list[i]);
1586 vcd_server_widget_finalize(client_list[i]);
1589 result = vcdc_send_hello(client_list[i], VCD_CLIENT_TYPE_WIDGET);
1592 SLOG(LOG_DEBUG, TAG_VCD, "[Server] widget pid(%d) should be removed.", client_list[i]);
1593 vcd_server_widget_finalize(client_list[i]);
1594 } else if (-1 == result) {
1595 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Hello result has error");
1600 SLOG(LOG_DEBUG, TAG_VCD, "@@@");
1603 if (NULL != client_list) {
1611 int mgr_pid = vcd_client_manager_get_pid();
1613 for (j = 0; j < g_list_length(g_proc_list); j++) {
1614 iter = g_list_nth(g_proc_list, j);
1616 if (mgr_pid == GPOINTER_TO_INT(iter->data)) {
1617 SLOG(LOG_DEBUG, TAG_VCD, "manager pid(%d) is running", mgr_pid);
1624 if (false == exist) {
1625 SLOG(LOG_ERROR, TAG_VCD, "manager pid (%d) should be removed", mgr_pid);
1626 vcd_server_mgr_finalize(mgr_pid);
1633 int vcd_server_get_service_state()
1635 return vcd_config_get_service_state();
1638 int vcd_server_get_foreground()
1641 vcd_config_get_foreground(&pid);
1645 static Eina_Bool __vcd_send_service_state(void *data)
1647 vcd_config_set_service_state(VCD_STATE_READY);
1648 vcdc_send_service_state(VCD_STATE_READY);
1650 SLOG(LOG_INFO, TAG_VCD, "[Server Success] success to send service status for READY");
1658 int vcd_server_mgr_initialize(int pid)
1660 /* check if pid is valid */
1661 if (false == vcd_client_manager_is_valid(pid)) {
1662 SLOG(LOG_ERROR, TAG_VCD, "[Server] old manager pid(%d) be removed", vcd_client_manager_get_pid());
1663 vcd_server_mgr_cancel();
1664 vcd_client_manager_unset();
1667 /* Add client information to client manager */
1668 int ret = vcd_client_manager_set(pid);
1670 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to add manager");
1671 return VCD_ERROR_OPERATION_FAILED;
1674 if (0 != vcdc_send_manager_pid(pid))
1675 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send manager pid");
1677 ecore_timer_add(0.05, __vcd_send_service_state, NULL);
1679 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] Manager initialize : pid(%d)", pid);
1681 return VCD_ERROR_NONE;
1684 int vcd_server_mgr_finalize(int pid)
1686 /* check if pid is valid */
1687 if (false == vcd_client_manager_is_valid(pid)) {
1688 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
1689 return VCD_ERROR_INVALID_PARAMETER;
1692 /* Cancel recognition */
1693 vcd_server_mgr_cancel();
1695 if (0 != vcdc_send_manager_pid(-1))
1696 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to send manager pid");
1698 /* Remove manager information */
1699 if (0 != vcd_client_manager_unset()) {
1700 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to delete client");
1703 if (0 == vcd_client_get_ref_count()) {
1704 SLOG(LOG_INFO, TAG_VCD, "[Server] Connected client list is empty");
1705 ecore_timer_add(0, __finalize_quit_ecore_loop, NULL);
1708 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] Manager Finalize : pid(%d)", pid);
1710 return VCD_ERROR_NONE;
1713 int vcd_server_mgr_set_command(int pid)
1715 if (0 != vcd_client_manager_set_command(pid)) {
1716 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
1717 return VCD_ERROR_INVALID_PARAMETER;
1719 return VCD_ERROR_NONE;
1722 int vcd_server_mgr_unset_command(int pid)
1724 if (0 != vcd_client_manager_unset_command(pid)) {
1725 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
1726 return VCD_ERROR_INVALID_PARAMETER;
1728 return VCD_ERROR_NONE;
1731 int vcd_server_mgr_set_demandable_client(int pid)
1733 /* check if pid is valid */
1734 if (false == vcd_client_manager_is_valid(pid)) {
1735 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
1736 return VCD_ERROR_INVALID_PARAMETER;
1739 GSList* client_list = NULL;
1740 if (0 != vc_info_parser_get_demandable_clients(&client_list)) {
1741 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get demandable client");
1742 return VCD_ERROR_OPERATION_FAILED;
1745 /* Save client list */
1746 if (0 != vcd_client_manager_set_demandable_client(pid, client_list)) {
1747 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set demandable client list");
1748 return VCD_ERROR_OPERATION_FAILED;
1751 return VCD_ERROR_NONE;
1754 int vcd_server_mgr_set_audio_type(int pid, const char* audio_type)
1756 /* check if pid is valid */
1757 if (false == vcd_client_manager_is_valid(pid)) {
1758 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
1759 return VCD_ERROR_INVALID_PARAMETER;
1763 vce_audio_type_e type = VCE_AUDIO_TYPE_PCM_S16_LE;
1767 ret = vcd_engine_get_audio_format(audio_type, &type, &rate, &channel);
1769 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get audio format : %d", ret);
1770 return VCD_ERROR_OPERATION_FAILED;
1773 ret = vcd_recorder_set(audio_type, type, rate, channel);
1775 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set audio in type : %d", ret);
1776 return VCD_ERROR_OPERATION_FAILED;
1779 return VCD_ERROR_NONE;
1782 int vcd_server_mgr_get_audio_type(int pid, char** audio_type)
1784 /* check if pid is valid */
1785 if (false == vcd_client_manager_is_valid(pid)) {
1786 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
1787 return VCD_ERROR_INVALID_PARAMETER;
1790 int ret = vcd_recorder_get(audio_type);
1792 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get audio in type : %d", ret);
1793 return VCD_ERROR_OPERATION_FAILED;
1796 return VCD_ERROR_NONE;
1799 int vcd_server_mgr_set_client_info(int pid)
1801 /* check if pid is valid */
1802 if (false == vcd_client_manager_is_valid(pid)) {
1803 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
1804 return VCD_ERROR_INVALID_PARAMETER;
1807 int ret = vcd_client_save_client_info();
1809 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to save client info : %d", ret);
1810 return VCD_ERROR_OPERATION_FAILED;
1813 return VCD_ERROR_NONE;
1816 static int __reset_waiting_for_widget_recording(void)
1818 SLOG(LOG_ERROR, TAG_VCD, "[Server] Reset waiting for widget recording");
1819 // Delete timer to check that widget client is terminated
1820 if (g_check_widget_client_timer) {
1821 ecore_timer_del(g_check_widget_client_timer);
1822 g_check_widget_client_timer = NULL;
1824 // Reset flag to wait for recording from widget client
1825 vcd_client_widget_set_waiting_for_recording(-1, false);
1830 static Eina_Bool __send_waiting_timeout_error_to_manager(void* data)
1832 intptr_t ppid = (intptr_t)data;
1833 int pid = (int)ppid;
1834 SLOG(LOG_ERROR, TAG_VCD, "Widget client didn't send to start recording, pid(%d)", pid);
1835 __reset_waiting_for_widget_recording();
1837 vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), VCD_ERROR_OPERATION_FAILED, "voice_engine.error.proc_fail");
1841 static Eina_Bool __send_waiting_timeout_start_recording(void* data)
1843 intptr_t ppid = (intptr_t)data;
1844 int pid = (int)ppid;
1845 SLOG(LOG_ERROR, TAG_VCD, "Widget client didn't send to start recording, pid(%d)", pid);
1847 int ret = __start_internal_recognition();
1849 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to start recognition : %d", ret);
1856 static int __set_waiting_for_widget_recording(int pid)
1858 SLOG(LOG_ERROR, TAG_VCD, "[Server] Set waiting for widget recording, pid(%d)", pid);
1860 // Check if the app included widget client is terminated or not. If it is terminated, vcd_server_widget_finalize() function will be called
1861 // In that function, it will start recording
1862 intptr_t ppid = (intptr_t)pid;
1863 g_check_widget_client_timer = ecore_timer_add(2.0, __send_waiting_timeout_start_recording, (void*)ppid);
1865 // Set flag to wait for recording from widget client
1866 vcd_client_widget_set_waiting_for_recording(pid, true);
1870 static int __start_internal_recognition()
1873 __reset_waiting_for_widget_recording();
1875 if (0 != vcd_client_command_collect_command()) {
1876 SLOG(LOG_ERROR, TAG_VCD, "[Client Data ERROR] Fail to collect command");
1877 /* Send error cb to manager */
1878 int pid = vcd_client_widget_get_foreground_pid();
1880 vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), VCD_ERROR_OPERATION_FAILED, "voice_framework.error.vcfw.collect_command_fail");
1881 return VCD_ERROR_OPERATION_FAILED;
1884 /* 3. Set command to engine */
1885 ret = vcd_engine_set_commands();
1887 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set commands : %d", ret);
1888 /* Send error cb to manager */
1889 int pid = vcd_client_widget_get_foreground_pid();
1891 vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), VCD_ERROR_OPERATION_FAILED, "voice_framework.error.engine.set_commands_fail");
1892 return VCD_ERROR_OPERATION_FAILED;
1895 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] Set command");
1897 bool stop_by_silence = true;
1898 if (VCD_RECOGNITION_MODE_MANUAL == vcd_client_get_recognition_mode()) {
1899 stop_by_silence = false;
1902 vcd_client_manager_set_result_text(NULL);
1904 /* 4. start recognition */
1905 ret = vcd_engine_recognize_start(stop_by_silence);
1907 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to start recognition : result(%d)", ret);
1908 /* Send error cb to manager */
1909 int pid = vcd_client_widget_get_foreground_pid();
1911 vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), VCD_ERROR_OPERATION_FAILED, "voice_framework.error.engine.start_fail");
1912 return VCD_ERROR_OPERATION_FAILED;
1915 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] Start engine");
1918 /* 5. recorder start */
1919 ret = vcd_recorder_start();
1921 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to start recorder : result(%d)", ret);
1922 vcd_engine_recognize_cancel();
1923 /* Send error cb to manager */
1924 int pid = vcd_client_widget_get_foreground_pid();
1926 vcdc_send_error_signal_to_manager(vcd_client_manager_get_pid(), VCD_ERROR_OPERATION_FAILED, "voice_framework.error.vcfw.send_rc_fail");
1931 vcd_config_set_service_state(VCD_STATE_RECORDING);
1932 vcdc_send_service_state(VCD_STATE_RECORDING);
1934 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] Start recognition(%d)", stop_by_silence);
1939 static Eina_Bool __vcd_request_show_tooltip(void *data)
1941 int pid = vcd_client_widget_get_foreground_pid();
1943 SLOG(LOG_ERROR, TAG_VCD, "[Server] Request tooltip show and widget command, show(%d)", (bool)data);
1944 vcdc_send_show_tooltip(pid, (bool)data);
1950 int vcd_server_mgr_start(vcd_recognition_mode_e recognition_mode, bool exclusive_cmd, bool start_by_client)
1952 /* 1. check current state */
1953 vcd_state_e state = vcd_config_get_service_state();
1955 if (VCD_STATE_READY != state && VCD_STATE_SYNTHESIZING != state) {
1956 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready and not synthesizine, state(%d)", state);
1957 return VCD_ERROR_INVALID_STATE;
1959 if (-1 == vcd_client_manager_get_pid()) {
1960 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Manager is NOT available.");
1961 return VCD_ERROR_OPERATION_FAILED;
1963 __reset_waiting_for_widget_recording();
1965 SLOG(LOG_ERROR, TAG_VCD, "[Server] set recognition mode = %d", recognition_mode);
1966 vcd_client_set_recognition_mode(recognition_mode);
1968 if (false == exclusive_cmd) {
1969 vcd_client_update_foreground_pid();
1970 /* Notify show tooltip */
1971 if (1 == vcd_config_get_command_type_enabled(VC_COMMAND_TYPE_WIDGET)) {
1972 int pid = vcd_client_widget_get_foreground_pid();
1974 SLOG(LOG_ERROR, TAG_VCD, "[Server] Request tooltip show and widget command");
1975 ecore_timer_add(0, __vcd_request_show_tooltip, (void*)true);
1977 __set_waiting_for_widget_recording(pid);
1982 vcd_client_manager_set_exclusive(exclusive_cmd);
1986 if (true == start_by_client) {
1987 /* Get foreground pid */
1988 if (0 != vcd_config_get_foreground(&fg_pid)) {
1989 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get foreground");
1992 /* Set client exclusive option */
1993 if (0 != vcd_client_set_exclusive_command(fg_pid)) {
1994 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set exclusive command");
1998 SLOG(LOG_ERROR, TAG_VCD, "[Server] start internal recognition");
2000 int ret = __start_internal_recognition();
2002 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to start recognition : %d", ret);
2006 if (true == start_by_client) {
2007 vcd_client_unset_exclusive_command(fg_pid);
2010 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] start internal recognition");
2011 return VCD_ERROR_NONE;
2014 int vcd_server_mgr_stop()
2016 /* 1. Check current state is recording */
2017 if (VCD_STATE_RECORDING != vcd_config_get_service_state()) {
2018 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not recording");
2019 return VCD_ERROR_INVALID_STATE;
2021 if (-1 == vcd_client_manager_get_pid()) {
2022 SLOG(LOG_INFO, TAG_VCD, "[Server] Manager is NOT available.");
2023 return VCD_ERROR_OPERATION_FAILED;
2025 SLOG(LOG_ERROR, TAG_VCD, "[Server] stop internal recognition");
2028 /* 2. Stop recorder */
2029 vcd_recorder_stop();
2032 /* 3. Stop engine recognition */
2033 int ret = vcd_engine_recognize_stop();
2035 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to stop recognition : %d", ret);
2038 /* 4. Set original mode */
2039 vcd_config_set_service_state(VCD_STATE_PROCESSING);
2040 vcdc_send_service_state(VCD_STATE_PROCESSING);
2042 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] stop internal recognition");
2043 return VCD_ERROR_NONE;
2046 int vcd_server_mgr_cancel()
2048 if (-1 == vcd_client_manager_get_pid()) {
2049 SLOG(LOG_ERROR, TAG_VCD, "[Server] Manager is NOT available.");
2050 return VCD_ERROR_OPERATION_FAILED;
2053 if (g_restart_timer != NULL) {
2054 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Delete restart engine timer");
2055 ecore_timer_del(g_restart_timer);
2056 g_restart_timer = NULL;
2059 /* 1. Check current state */
2060 vcd_state_e state = vcd_config_get_service_state();
2061 if (VCD_STATE_READY == state) {
2062 SLOG(LOG_INFO, TAG_VCD, "[Server] Current state is READY");
2063 vcd_recorder_stop();
2065 if (false == vcd_client_manager_get_exclusive()) {
2066 if (1 == vcd_config_get_command_type_enabled(VC_COMMAND_TYPE_WIDGET)) {
2067 int pid = vcd_client_widget_get_foreground_pid();
2069 SLOG(LOG_INFO, TAG_VCD, "[Server] Request tooltip hide");
2070 ecore_timer_add(0, __vcd_request_show_tooltip, (void*)false);
2075 vcdc_send_service_state(VCD_STATE_READY);
2076 return VCD_ERROR_NONE;
2078 SLOG(LOG_ERROR, TAG_VCD, "[Server] cancel internal recognition");
2081 /* 2. Stop recorder */
2082 vcd_recorder_stop();
2085 /* 3. Cancel engine */
2086 int ret = vcd_engine_recognize_cancel();
2088 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to cancel : %d", ret);
2091 if (false == vcd_client_manager_get_exclusive()) {
2092 if (1 == vcd_config_get_command_type_enabled(VC_COMMAND_TYPE_WIDGET)) {
2093 int pid = vcd_client_widget_get_foreground_pid();
2095 SLOG(LOG_INFO, TAG_VCD, "[Server] Request tooltip hide");
2096 ecore_timer_add(0, __vcd_request_show_tooltip, (void*)false);
2100 vcd_client_manager_set_exclusive(false);
2104 vcd_config_set_service_state(VCD_STATE_READY);
2105 vcdc_send_service_state(VCD_STATE_READY);
2107 SLOG(LOG_ERROR, TAG_VCD, "[Server Success] cancel internal recognition");
2108 return VCD_ERROR_NONE;
2112 int vcd_server_mgr_result_select()
2114 __vcd_send_selected_result(NULL);
2116 return VCD_ERROR_NONE;
2119 int vcd_server_mgr_set_domain(int pid, const char* domain)
2121 /* check if pid is valid */
2122 if (false == vcd_client_manager_is_valid(pid)) {
2123 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
2124 return VCD_ERROR_INVALID_PARAMETER;
2127 vcd_state_e state = vcd_config_get_service_state();
2128 if (VCD_STATE_READY != state) {
2129 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready");
2130 return VCD_ERROR_INVALID_STATE;
2133 /* Set domain to engine */
2134 int ret = vcd_engine_set_domain(pid, domain);
2136 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set domain : %d", ret);
2138 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] Set domain");
2144 int vcd_server_mgr_set_private_data(int pid, const char* key, const char* data)
2146 /* check if pid is valid */
2147 if (false == vcd_client_manager_is_valid(pid)) {
2148 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
2149 return VCD_ERROR_INVALID_PARAMETER;
2152 vcd_state_e state = vcd_config_get_service_state();
2153 if (VCD_STATE_READY != state) {
2154 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready");
2155 return VCD_ERROR_INVALID_STATE;
2158 /* Set private data to engine */
2159 int ret = vcd_engine_set_private_data(pid, key, data);
2161 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set private data : %d", ret);
2163 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] Set private data");
2169 int vcd_server_mgr_get_private_data(int pid, const char* key, char** data)
2171 /* check if pid is valid */
2172 if (false == vcd_client_manager_is_valid(pid)) {
2173 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
2174 return VCD_ERROR_INVALID_PARAMETER;
2176 vcd_state_e state = vcd_config_get_service_state();
2177 if (VCD_STATE_READY != state) {
2178 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready");
2179 return VCD_ERROR_INVALID_STATE;
2182 /* Get private data to engine */
2183 int ret = vcd_engine_get_private_data(pid, key, data);
2185 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get private data : %d", ret);
2187 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] Set private data");
2193 int vcd_server_mgr_send_specific_engine_request(int pid, const char* engine_app_id, const char* event, const char* request)
2195 /* check if pid is valid */
2196 if (false == vcd_client_manager_is_valid(pid)) {
2197 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
2198 return VCD_ERROR_INVALID_PARAMETER;
2200 vcd_state_e state = vcd_config_get_service_state();
2201 if (VCD_STATE_READY != state && VCD_STATE_SYNTHESIZING != state) {
2202 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready and not synthesizing, state(%d)", state);
2203 return VCD_ERROR_INVALID_STATE;
2206 /* Get private data to engine */
2207 int ret = vcd_engine_send_specific_engine_request(engine_app_id, event, request);
2209 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set specific engine request : %d", ret);
2211 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] Set specific engine request ");
2217 int vcd_server_mgr_do_action(int pid, int type, const char* action)
2221 /* check if pid is valid */
2222 if (false == vcd_client_manager_is_valid(pid)) {
2223 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
2224 return VCD_ERROR_INVALID_PARAMETER;
2227 vcd_state_e state = vcd_config_get_service_state();
2228 if (VCD_STATE_READY != state && VCD_STATE_SYNTHESIZING != state) {
2229 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready and not synthesizing, state(%d)", state);
2230 return VCD_ERROR_INVALID_STATE;
2233 /* Request do action to engine */
2234 if (VCD_SEND_EVENT_TYPE_TEXT == type)
2235 ret = vcd_engine_process_text(pid, action);
2236 else if (VCD_SEND_EVENT_TYPE_LIST_EVENT == type)
2237 ret = vcd_engine_process_list_event(pid, action);
2238 else if (VCD_SEND_EVENT_TYPE_HAPTIC_EVENT == type)
2239 ret = vcd_engine_process_haptic_event(pid, action);
2242 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to process do action : %d", ret);
2244 vcd_config_set_service_state(VCD_STATE_PROCESSING);
2245 vcdc_send_service_state(VCD_STATE_PROCESSING);
2246 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] Process do action");
2252 int vcd_server_mgr_set_disabled_command_type(int pid, int disabled_cmd_type)
2256 /* check if pid is valid */
2257 if (false == vcd_client_manager_is_valid(pid)) {
2258 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] The manager pid(%d) is NOT valid", pid);
2259 return VCD_ERROR_INVALID_PARAMETER;
2262 vcd_state_e state = vcd_config_get_service_state();
2263 if (VCD_STATE_READY != state) {
2264 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready");
2265 return VCD_ERROR_INVALID_STATE;
2268 ret = vcd_config_set_disabled_command_type(disabled_cmd_type);
2270 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set command type");
2272 SLOG(LOG_ERROR, TAG_VCD, "[Server] Set command type(%d)", disabled_cmd_type);
2279 /* for TTS feedback */
2280 int vcd_server_mgr_start_feedback(void)
2282 /* check current state */
2283 /* not Recording??? */
2285 if (-1 == vcd_client_manager_get_pid()) {
2286 SLOG(LOG_ERROR, TAG_VCD, "[Server] Manager is NOT available");
2287 return VCD_ERROR_OPERATION_FAILED;
2290 SLOG(LOG_INFO, TAG_VCD, "[Server] start TTS feedback");
2292 /* check there is TTS buffer to be spoken */
2294 return VCD_ERROR_NONE;
2297 int vcd_server_mgr_stop_feedback(void)
2299 /* check current state */
2300 /* not Recording??? */
2302 if (-1 == vcd_client_manager_get_pid()) {
2303 SLOG(LOG_ERROR, TAG_VCD, "[Server] Manager is NOT available");
2304 return VCD_ERROR_OPERATION_FAILED;
2307 SLOG(LOG_INFO, TAG_VCD, "[Server] stop TTS feedback");
2309 return VCD_ERROR_NONE;
2312 int vcd_server_mgr_send_audio_streaming(int pid, int event, unsigned char* buffer, unsigned int len)
2314 SLOG(LOG_INFO, TAG_VCD, "[DEBUG] Send Audio Streaming from Multi-assistant. event(%d), buffer(%p), len(%d)", event, &buffer, len);
2317 if (VCD_AUDIO_STREAMING_EVENT_START == event) {
2318 ret = vcd_recorder_start_streaming();
2320 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to start streaming, ret(%d)", ret);
2325 ret = vcd_recorder_send_streaming((const void*)buffer, (const unsigned int)len);
2327 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to start streaming, ret(%d)", ret);
2331 if (VCD_AUDIO_STREAMING_EVENT_FINISH == event) {
2332 ret = vcd_recorder_stop_streaming();
2334 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to stop streaming, ret(%d)", ret);
2339 return VCD_ERROR_NONE;
2342 int vcd_server_mgr_change_system_volume(int pid, vcd_system_volume_event_e system_volume_event)
2344 SLOG(LOG_INFO, TAG_VCD, "[DEBUG] change system volume, system volume event(%d)", system_volume_event);
2347 if (VCD_SYSTEM_VOLUME_EVENT_CHANGE == system_volume_event) {
2348 ret = vcd_recorder_change_system_volume();
2350 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to change system volume, ret(%d)", ret);
2353 } else if (VCD_SYSTEM_VOLUME_EVENT_RECOVER == system_volume_event) {
2354 ret = vcd_recorder_recover_system_volume();
2356 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to recover system volume, ret(%d)", ret);
2366 * VC Server Functions for Client
2368 int vcd_server_initialize(int pid)
2370 if (false == vcd_engine_is_available_engine()) {
2371 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] No Engine");
2372 return VCD_ERROR_ENGINE_NOT_FOUND;
2375 /* check if pid is valid */
2376 if (true == vcd_client_is_available(pid)) {
2377 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] The pid is already exist");
2378 return VCD_ERROR_NONE;
2381 /* Add client information to client manager */
2382 if (0 != vcd_client_add(pid)) {
2383 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to add client info");
2384 return VCD_ERROR_OPERATION_FAILED;
2387 SLOG(LOG_INFO, TAG_VCD, "[Server Success] Client Initialize : pid(%d)", pid);
2389 return VCD_ERROR_NONE;
2392 int vcd_server_finalize(int pid)
2394 /* check if pid is valid */
2395 if (false == vcd_client_is_available(pid)) {
2396 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2397 return VCD_ERROR_INVALID_PARAMETER;
2400 /* Remove client information */
2401 if (0 != vcd_client_delete(pid)) {
2402 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to delete client");
2405 if (0 == vcd_client_get_ref_count()) {
2406 SLOG(LOG_INFO, TAG_VCD, "[Server] Connected client list is empty");
2407 ecore_timer_add(0, __finalize_quit_ecore_loop, NULL);
2410 SLOG(LOG_INFO, TAG_VCD, "[Server Success] Client Finalize : pid(%d)", pid);
2412 return VCD_ERROR_NONE;
2415 int vcd_server_set_command(int pid, vc_cmd_type_e cmd_type)
2417 /* check if pid is valid */
2418 if (false == vcd_client_is_available(pid)) {
2419 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2420 return VCD_ERROR_INVALID_PARAMETER;
2423 if (0 != vcd_client_set_command_type(pid, cmd_type)) {
2424 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set command type : pid(%d), cmd_type(%d)", pid, cmd_type);
2425 return VCD_ERROR_OPERATION_FAILED;
2431 int vcd_server_unset_command(int pid, vc_cmd_type_e cmd_type)
2433 /* check if pid is valid */
2434 if (false == vcd_client_is_available(pid)) {
2435 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2436 return VCD_ERROR_INVALID_PARAMETER;
2439 if (0 != vcd_client_unset_command_type(pid, cmd_type)) {
2440 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to unset command type : pid(%d), cmd_type(%d)", pid, cmd_type);
2441 return VCD_ERROR_OPERATION_FAILED;
2447 int vcd_server_set_foreground(int pid, bool value)
2449 /* check if pid is valid */
2450 if (false == vcd_client_is_available(pid) && false == vcd_client_widget_is_available(pid)) {
2451 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2452 return VCD_ERROR_INVALID_PARAMETER;
2455 if (0 != vcd_config_set_foreground(pid, value)) {
2456 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set foreground : pid(%d), value(%d)", pid, value);
2457 return VCD_ERROR_OPERATION_FAILED;
2463 static int __vcd_server_launch_manager_app()
2466 bool running = false;
2469 ret = vcd_client_manager_get_appid(&appid);
2470 if (0 != ret || NULL == appid) {
2471 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to get manager appid");
2472 return VCD_ERROR_OPERATION_FAILED;
2474 ret = app_manager_is_running(appid, &running);
2476 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to check running with appid(%s)", appid);
2479 return VCD_ERROR_OPERATION_FAILED;
2481 if (false == running) {
2482 int tmp_ret = __vcd_is_package_installed(appid);
2483 if (false == tmp_ret) {
2484 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] manager app is not installed, appid(%s)", appid);
2486 ret = __vcd_activate_app_by_appcontrol(appid);
2488 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to activate app");
2493 SLOG(LOG_ERROR, TAG_VCD, "Launch vc manager app: appid(%s)", appid);
2496 ret = __vcd_resume_app(appid);
2498 SLOG(LOG_ERROR, TAG_VCD, "[ERROR] Fail to resume app");
2503 SLOG(LOG_ERROR, TAG_VCD, "Resume vc manager app: appid(%s)", appid);
2509 return VCD_ERROR_NONE;
2512 int vcd_server_set_server_dialog(int pid, const char* app_id, const char* credential)
2514 /* check if pid is valid */
2515 if (false == vcd_client_is_available(pid)) {
2516 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2517 return VCD_ERROR_INVALID_PARAMETER;
2520 int ret = vcd_engine_set_server_dialog(app_id, credential);
2522 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set server dialog, pid(%d), app_id(%s), ret(%d)", pid, app_id, ret);
2523 vcd_client_set_server_dialog(pid, false);
2526 SLOG(LOG_ERROR, TAG_VCD, "[Success] Set server dialog, pid(%d), app_id(%s)", pid, app_id);
2528 if (0 != strncmp(credential, "#NULL", strlen(credential))) {
2529 ret = vcd_client_set_server_dialog(pid, true);
2531 SLOG(LOG_INFO, TAG_VCD, "[Server] Set to true for server dialog, app_id(%s)", app_id);
2533 ret = vcd_client_set_server_dialog(pid, false);
2535 SLOG(LOG_INFO, TAG_VCD, "[Server] Set to false for server dialog, app_id(%s)", app_id);
2541 int vcd_server_dialog(int pid, const char* disp_text, const char* utt_text, int continuous)
2543 /* check if pid is valid */
2544 if (false == vcd_client_is_available(pid) && false == vcd_client_widget_is_available(pid)) {
2545 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2546 return VCD_ERROR_INVALID_PARAMETER;
2549 bool is_server_dialog = false;
2550 int ret = vcd_client_get_server_dialog(pid, &is_server_dialog);
2552 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get server dialog, pid(%d), ret(%d)", pid, ret);
2555 if (true == is_server_dialog) {
2556 /* ++ Request tts event to engine */
2558 /* -- Request tts event to engine */
2560 ret = __vcd_server_launch_manager_app();
2562 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send dialog : mgr_pid(%d), pid(%d), disp_text(%s), utt_text(%s), continue(%d)", vcd_client_manager_get_pid(), pid, disp_text, utt_text, continuous);
2566 ret = vcdc_send_dialog(vcd_client_manager_get_pid(), pid, disp_text, utt_text, continuous);
2568 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to send dialog : mgr_pid(%d), pid(%d), disp_text(%s), utt_text(%s), continue(%d)", vcd_client_manager_get_pid(), pid, disp_text, utt_text, continuous);
2575 int vcd_server_is_system_command_valid(int pid, int* is_sys_cmd_valid)
2577 /* check if pid is valid */
2578 if (false == vcd_client_is_available(pid) && false == vcd_client_widget_is_available(pid)) {
2579 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2580 return VCD_ERROR_INVALID_PARAMETER;
2583 /* check if system command is valid */
2584 if (true == vcd_client_manager_is_system_command_valid(vcd_client_manager_get_pid()))
2585 *is_sys_cmd_valid = true;
2587 *is_sys_cmd_valid = false;
2592 static void __start_tts_request_thread(void* data, Ecore_Thread* thread)
2594 SLOG(LOG_INFO, TAG_VCD, "[SUCCESS] Start tts request thread");
2595 vc_tts_text_data_s* tts_text_data = NULL;
2601 /* Get tts text data */
2602 ret = vcd_data_get_first_tts_text_data(&tts_text_data);
2603 if (0 != ret || NULL == tts_text_data) {
2605 if (0 >= vcd_data_get_tts_text_data_size()) {
2606 SLOG(LOG_INFO, TAG_VCD, "[DEBUG] No tts text data");
2609 SLOG(LOG_INFO, TAG_VCD, "[INFO] tts text data is just incoming");
2614 vcd_state_e state = vcd_config_get_service_state();
2615 if (VCD_STATE_READY != state) {
2616 if (0 == cnt++ % 10)
2617 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Waiting to request TTS, state(%d)", state);
2624 /* Set service state to synthesizing */
2625 vcd_config_set_service_state(VCD_STATE_SYNTHESIZING);
2627 /* Set current uid */
2628 g_current_uid = tts_text_data->uid;
2630 /* Request tts to engine */
2631 ret = vcd_engine_request_tts(tts_text_data->pid, tts_text_data->utt_id, tts_text_data->text, tts_text_data->language);
2633 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to request tts : %d", ret);
2635 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] request tts, uid(%d) pid(%d), text(%s), language(%s), utt_id(%d)",
2636 tts_text_data->uid, tts_text_data->pid, tts_text_data->text, tts_text_data->language, tts_text_data->utt_id);
2638 /* clear tts text data after use */
2639 vcd_data_clear_tts_text_data(&tts_text_data);
2644 static void __end_tts_request_thread(void* data, Ecore_Thread* thread)
2646 SLOG(LOG_INFO, TAG_VCD, "[SUCCESS] End tts request thread");
2647 g_tts_thread = NULL;
2650 int vcd_server_request_tts(int pid, const char* text, const char* language, int to_vcm, int* utt_id)
2652 /* check if pid is valid */
2653 if (false == vcd_client_is_available(pid)) {
2654 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2655 return VCD_ERROR_INVALID_PARAMETER;
2658 vcd_state_e state = vcd_config_get_service_state();
2659 if (VCD_STATE_READY != state && VCD_STATE_SYNTHESIZING != state) {
2660 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready, state(%d)", state);
2661 return VCD_ERROR_INVALID_STATE;
2665 g_current_utt_id = (g_current_utt_id + 1) % 1000;
2666 *utt_id = g_current_utt_id;
2668 uid = pid * 1000 + g_current_utt_id;
2670 uid = vcd_client_manager_get_pid() * 1000 + g_current_utt_id;
2672 SLOG(LOG_INFO, TAG_VCD, "[Server INFO] pid(%d), text(%s), language(%s), to_vcm(%d), ", pid, text, language, to_vcm);
2673 SLOG(LOG_INFO, TAG_VCD, "[Server INFO] current_uid(%d), current_utt_id(%d)", uid, g_current_utt_id);
2675 vc_tts_text_data_s* tts_text_data;
2676 tts_text_data = (vc_tts_text_data_s*)calloc(1, sizeof(vc_tts_text_data_s));
2677 if (!tts_text_data) {
2678 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to callocate memory ");
2679 return VCD_ERROR_OUT_OF_MEMORY;
2681 tts_text_data->uid = uid;
2682 tts_text_data->pid = pid;
2683 tts_text_data->utt_id = g_current_utt_id;
2684 tts_text_data->text = strdup(text);
2685 tts_text_data->language = strdup(language);
2687 int ret = vcd_data_add_tts_text_data(tts_text_data->uid, tts_text_data);
2689 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to add tts text data : %d", ret);
2692 bool is_canceled = ecore_thread_check(g_tts_thread);
2693 if (NULL == g_tts_thread || TRUE == is_canceled) {
2694 SLOG(LOG_INFO, TAG_VCD, "[Server INFO] ecore thread run : start_tts_request_thread ");
2695 g_tts_thread = ecore_thread_run(__start_tts_request_thread, __end_tts_request_thread, NULL, NULL);
2701 int vcd_server_cancel_tts(int pid, int utt_id)
2703 /* check if pid is valid */
2704 if (false == vcd_client_is_available(pid)) {
2705 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2706 return VCD_ERROR_INVALID_PARAMETER;
2709 vcd_state_e state = vcd_config_get_service_state();
2710 if (VCD_STATE_READY != state && VCD_STATE_SYNTHESIZING != state) {
2711 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready, state(%d)", state);
2712 return VCD_ERROR_INVALID_STATE;
2715 vc_tts_text_data_s* tts_text_data = NULL;
2717 int uid = pid * 1000 + utt_id;
2718 int ret = vcd_data_get_tts_text_data(uid, &tts_text_data);
2720 SLOG(LOG_WARN, TAG_VCD, "[Server WARN] No data in vcd tts text queue");
2722 SLOG(LOG_INFO, TAG_VCD, "[Server] Clear tts text data, pid(%d), utt_id(%d), text(%s)", pid, utt_id, tts_text_data->text);
2723 vcd_data_clear_tts_text_data(&tts_text_data);
2726 /* Request tts to engine */
2727 ret = vcd_engine_cancel_tts(pid, utt_id);
2729 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to cancel tts : %d", ret);
2731 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] request tts, pid(%d), utt_id(%d)", pid, utt_id);
2737 int vcd_server_get_tts_audio_format(int pid, int* rate, int* channel, int* audio_type)
2739 /* check if pid is valid */
2740 if (false == vcd_client_is_available(pid)) {
2741 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2742 return VCD_ERROR_INVALID_PARAMETER;
2745 vcd_state_e state = vcd_config_get_service_state();
2746 if (VCD_STATE_READY != state && VCD_STATE_SYNTHESIZING != state) {
2747 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state is not ready and not synthesizing, state(%d)", state);
2748 return VCD_ERROR_INVALID_STATE;
2751 /* Request tts to engine */
2752 int ret = vcd_engine_get_tts_audio_format(rate, channel, audio_type);
2754 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get tts audio format : %d", ret);
2756 SLOG(LOG_INFO, TAG_VCD, "[Server SUCCESS] get tts audio format, pid(%d), rate(%d), channel(%d), audio_type(%d)", pid, *rate, *channel, *audio_type);
2763 int vcd_server_set_exclusive_command(int pid, bool value)
2765 /* check if pid is valid */
2766 if (false == vcd_client_is_available(pid)) {
2767 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2768 return VCD_ERROR_INVALID_PARAMETER;
2771 if (true == value) {
2772 if (0 != vcd_client_set_exclusive_command(pid)) {
2773 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set exclusive command : pid(%d)", pid);
2774 return VCD_ERROR_OPERATION_FAILED;
2777 if (0 != vcd_client_unset_exclusive_command(pid)) {
2778 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to unset exclusive command : pid(%d)", pid);
2779 return VCD_ERROR_OPERATION_FAILED;
2786 int vcd_server_request_start(int pid, bool stop_by_silence)
2788 /* check if pid is valid */
2789 if (false == vcd_client_is_available(pid)) {
2790 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid(%d) is NOT foreground client", pid);
2791 return VCD_ERROR_INVALID_PARAMETER;
2795 /* Check current state */
2796 vcd_state_e state = vcd_config_get_service_state();
2798 /* Service state should be ready */
2799 if (VCD_STATE_READY != state) {
2800 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Current state is not Ready : pid(%d)", pid);
2801 return VCD_ERROR_INVALID_STATE;
2804 if (-1 != vcd_client_manager_get_pid()) {
2805 /* Check current pid is valid */
2806 if (false == vcd_client_manager_check_demandable_client(pid)) {
2807 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Current client is NOT available : pid(%d)", pid);
2808 return VCD_ERROR_INVALID_PARAMETER;
2812 ret = vcd_server_mgr_start(stop_by_silence, false);
2814 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Fail to start recognition");
2815 return VCD_ERROR_INVALID_PARAMETER;
2821 int vcd_server_request_stop(int pid)
2824 /* Check current state */
2825 vcd_state_e state = vcd_config_get_service_state();
2827 /* Service state should be ready */
2828 if (VCD_STATE_RECORDING != state) {
2829 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Current state is not Recording : pid(%d)", pid);
2830 return VCD_ERROR_INVALID_STATE;
2833 if (-1 != vcd_client_manager_get_pid()) {
2834 /* Check current pid is valid */
2835 if (false == vcd_client_manager_check_demandable_client(pid)) {
2836 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Current client is NOT available : pid(%d)", pid);
2837 return VCD_ERROR_INVALID_PARAMETER;
2841 ret = vcd_server_mgr_stop();
2843 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Fail to start recognition");
2844 return VCD_ERROR_OPERATION_FAILED;
2847 return VCD_ERROR_NONE;
2850 int vcd_server_request_cancel(int pid)
2853 /* Check current state */
2854 vcd_state_e state = vcd_config_get_service_state();
2856 /* Service state should be recording or processing */
2857 if (VCD_STATE_RECORDING != state && VCD_STATE_PROCESSING != state) {
2858 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Current state is not Recording or Processing : pid(%d)", pid);
2859 return VCD_ERROR_INVALID_STATE;
2862 if (-1 != vcd_client_manager_get_pid()) {
2863 /* Check current pid is valid */
2864 if (false == vcd_client_manager_check_demandable_client(pid)) {
2865 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Current client is NOT available : pid(%d)", pid);
2866 return VCD_ERROR_INVALID_PARAMETER;
2870 ret = vcd_server_mgr_cancel();
2872 SLOG(LOG_DEBUG, TAG_VCD, "[Server] Fail to start recognition");
2873 return VCD_ERROR_OPERATION_FAILED;
2876 return VCD_ERROR_NONE;
2881 * VC Server Functions for Widget lib
2883 int vcd_server_widget_initialize(int pid)
2885 if (false == vcd_engine_is_available_engine()) {
2886 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] No Engine");
2887 return VCD_ERROR_ENGINE_NOT_FOUND;
2890 /* check if pid is valid */
2891 if (true == vcd_client_widget_is_available(pid)) {
2892 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] The pid is already exist");
2893 return VCD_ERROR_NONE;
2896 /* Add client information to client manager */
2897 if (0 != vcd_client_widget_add(pid)) {
2898 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to add client info");
2899 return VCD_ERROR_OPERATION_FAILED;
2902 SLOG(LOG_INFO, TAG_VCD, "[Server Success] Initialize widget : pid(%d)", pid);
2904 return VCD_ERROR_NONE;
2907 static void __vcd_server_widget_start_recording(void *data)
2909 SLOG(LOG_ERROR, TAG_VCD, "[Server INFO] start recording");
2911 if (0 != __start_internal_recognition()) {
2912 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to start recognition");
2916 int vcd_server_widget_finalize(int pid)
2918 /* check if pid is valid */
2919 if (false == vcd_client_widget_is_available(pid)) {
2920 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2921 if (0 == vcd_client_get_ref_count()) {
2922 SLOG(LOG_ERROR, TAG_VCD, "[Server] connected client list is empty, vc-service will be terminated");
2923 ecore_timer_add(0, __finalize_quit_ecore_loop, NULL);
2926 return VCD_ERROR_INVALID_PARAMETER;
2929 /* Remove client information */
2930 if (0 != vcd_client_widget_delete(pid)) {
2931 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to delete client");
2934 if (0 == vcd_client_get_ref_count()) {
2935 SLOG(LOG_ERROR, TAG_VCD, "[Server] connected client list is empty, vc-service will be terminated");
2936 ecore_timer_add(0, __finalize_quit_ecore_loop, NULL);
2940 bool is_waiting = false;
2941 if (0 != vcd_client_widget_get_waiting_for_recording(pid, &is_waiting)) {
2942 SLOG(LOG_WARN, TAG_VCD, "[Server WARNING] Fail to get waiting to recording");
2945 if (true == is_waiting) {
2946 SLOG(LOG_ERROR, TAG_VCD, "[Server INFO] invoke to start recording");
2947 ecore_main_loop_thread_safe_call_async(__vcd_server_widget_start_recording, NULL);
2949 return VCD_ERROR_NONE;
2952 int vcd_server_widget_start_recording(int pid, bool widget_command)
2954 /* check if pid is valid */
2955 if (false == vcd_client_widget_is_available(pid)) {
2956 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] pid is NOT valid ");
2957 return VCD_ERROR_INVALID_PARAMETER;
2961 if (0 != vcd_client_widget_get_waiting_for_recording(pid, &waiting) || false == waiting) {
2962 SLOG(LOG_ERROR, TAG_VCD, "[Server] Server is not waiting for recording, pid(%d), waiting(%d)", pid, waiting);
2966 if (true == widget_command) {
2967 vcd_client_widget_set_command(pid);
2968 SLOG(LOG_INFO, TAG_VCD, "[Server] widget command is available");
2970 vcd_client_widget_unset_command(pid);
2971 SLOG(LOG_WARN, TAG_VCD, "[Server] widget command is NOT available");
2974 SLOG(LOG_ERROR, TAG_VCD, "[Server] start internal recognition : %d", widget_command);
2975 int ret = __start_internal_recognition();
2977 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to start recognition : %d", ret);
2978 ecore_timer_add(0, __vcd_request_show_tooltip, (void*)false);
2984 int vcd_server_widget_start(int pid, bool stop_by_silence)
2986 /* check if pid is valid */
2987 int fore_pid = vcd_client_widget_get_foreground_pid();
2988 if (pid != fore_pid) {
2989 SLOG(LOG_ERROR, TAG_VCD, "[Server] pid is NOT foreground");
2990 return VCD_ERROR_INVALID_PARAMETER;
2993 /* Check current state */
2994 vcd_state_e state = vcd_config_get_service_state();
2996 /* Service state should be ready */
2997 if (VCD_STATE_READY != state) {
2998 SLOG(LOG_INFO, TAG_VCD, "[Server] Current state is not Ready : pid(%d)", pid);
2999 return VCD_ERROR_INVALID_STATE;
3002 vcd_client_set_slience_detection(stop_by_silence);
3004 /* Notify show tooltip */
3005 ecore_timer_add(0, __vcd_request_show_tooltip, (void*)true);
3010 int vcd_server_widget_stop(int pid)
3012 /* check if pid is valid */
3013 int fore_pid = vcd_client_widget_get_foreground_pid();
3014 if (pid != fore_pid) {
3015 SLOG(LOG_ERROR, TAG_VCD, "[Server] pid is NOT foreground");
3016 return VCD_ERROR_INVALID_PARAMETER;
3020 /* Check current state */
3021 vcd_state_e state = vcd_config_get_service_state();
3023 /* Service state should be recording */
3024 if (VCD_STATE_RECORDING != state) {
3025 SLOG(LOG_ERROR, TAG_VCD, "[Server] Current service state is not Recording : pid(%d)", pid);
3026 return VCD_ERROR_INVALID_STATE;
3029 ret = vcd_server_mgr_stop();
3031 SLOG(LOG_ERROR, TAG_VCD, "[Server] Fail to start recognition");
3032 return VCD_ERROR_OPERATION_FAILED;
3035 return VCD_ERROR_NONE;
3038 int vcd_server_widget_cancel(int pid)
3040 /* check if pid is valid */
3041 int fore_pid = vcd_client_widget_get_foreground_pid();
3042 if (pid != fore_pid) {
3043 SLOG(LOG_ERROR, TAG_VCD, "[Server] pid is NOT foreground");
3044 return VCD_ERROR_INVALID_PARAMETER;
3048 /* Check current state */
3049 vcd_state_e state = vcd_config_get_service_state();
3051 /* Service state should be recording or processing */
3052 if (VCD_STATE_RECORDING != state && VCD_STATE_PROCESSING != state) {
3053 SLOG(LOG_ERROR, TAG_VCD, "[Server] Current state is not Recording or Processing : pid(%d)", pid);
3054 return VCD_ERROR_INVALID_STATE;
3057 ret = vcd_server_mgr_cancel();
3059 SLOG(LOG_ERROR, TAG_VCD, "[Server] Fail to cancel recognition : %d", ret);
3063 return VCD_ERROR_NONE;
3066 int vcd_server_widget_enable_asr_result(int pid, bool enable)
3069 ret = vcd_client_widget_set_asr_result_enabled(pid, enable);
3071 SLOG(LOG_ERROR, TAG_VCD, "[Server] Fail to enable asr result : %d", ret);
3077 int vcd_server_set_language(const char* language)
3079 int ret = VCD_ERROR_NONE;
3081 ret = vcd_config_set_default_language(language);
3083 SLOG(LOG_ERROR, TAG_VCD, "[Server] Fail to set language : %d", ret);
3087 ret = vcd_engine_set_current_language(language);
3089 SLOG(LOG_ERROR, TAG_VCD, "[Server] Fail to set language : %d", ret);
3096 * For engine service
3098 int vcd_get_foreach_command(vce_cmd_h vce_command, vce_command_cb callback, void* user_data)
3100 SLOG(LOG_INFO, TAG_VCD, "[Server] Get foreach command");
3102 if (NULL == callback) {
3103 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] input parameter is NULL");
3104 return VCD_ERROR_INVALID_PARAMETER;
3108 ret = vcd_engine_agent_get_foreach_command(vce_command, callback, user_data);
3110 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get foreach command : ret(%d)", ret);
3116 int vcd_get_command_count(vce_cmd_h vce_command, int* count)
3118 SLOG(LOG_INFO, TAG_VCD, "[Server] Get command count");
3121 ret = vcd_engine_agent_get_command_count(vce_command, count);
3123 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get command count : ret(%d)", ret);
3129 int vcd_get_audio_type(char** audio_type)
3131 SLOG(LOG_INFO, TAG_VCD, "[Server] Get audio type");
3134 ret = vcd_engine_agent_get_audio_type(audio_type);
3136 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get audio type : ret(%d)", ret);
3142 int vcd_set_private_data(const char* key, const char* data)
3144 vcd_state_e state = vcd_config_get_service_state();
3146 if (VCD_STATE_READY != state) {
3147 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state(%d) is NOT 'READY'", state);
3148 return VCD_ERROR_INVALID_STATE;
3151 int ret = vcd_engine_agent_set_private_data(key, data);
3153 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set private data to the manager client : ret(%d)", ret);
3155 SLOG(LOG_INFO, TAG_VCD, "[Server] Set private data to the manager client, key(%s), data(%s)", key, data);
3161 int vcd_get_private_data(const char* key, char** data)
3163 vcd_state_e state = vcd_config_get_service_state();
3165 if (VCD_STATE_READY != state) {
3166 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Current state(%d) is NOT 'READY'", state);
3167 return VCD_ERROR_INVALID_STATE;
3170 int ret = vcd_engine_agent_get_private_data(key, data);
3172 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to get private data from the manager client : ret(%d)", ret);
3174 SLOG(LOG_INFO, TAG_VCD, "[Server] Get private data from the manager client, key(%s), data(%s)", key, *data);
3180 int vcd_start_recording()
3182 SLOG(LOG_INFO, TAG_VCD, "[Server] Start recording");
3185 ret = vcd_engine_agent_start_recording();
3187 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to start recording : ret(%d)", ret);
3193 int vcd_stop_recording()
3195 SLOG(LOG_INFO, TAG_VCD, "[Server] Stop recording");
3198 ret = vcd_engine_agent_stop_recording();
3200 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to stop recording : ret(%d)", ret);
3206 int vcd_send_update_status(vce_update_event_e update_event, const char* msg)
3208 SLOG(LOG_INFO, TAG_VCD, "[Server] update status, update event(%d), msg(%s)", update_event, msg);
3211 if (VCE_UPDATE_EVENT_START == update_event) {
3212 if (VCD_STATE_RECORDING == vcd_config_get_service_state() || VCD_STATE_PROCESSING == vcd_config_get_service_state()) {
3213 ret = vcd_server_mgr_cancel();
3215 SLOG(LOG_ERROR, TAG_VCD, "[Server Error] Fail to cancel, ret(%d)", ret);
3219 vcd_config_set_service_state(VCD_STATE_UPDATING);
3220 vcdc_send_service_state(VCD_STATE_UPDATING);
3222 } else if (VCE_UPDATE_EVENT_FINISH == update_event) {
3223 vcd_config_set_service_state(VCD_STATE_READY);
3224 vcdc_send_service_state(VCD_STATE_READY);
3226 } else if (VCE_UPDATE_EVENT_FAIL == update_event) {
3227 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Update event : Fail - msg(%s)", msg);
3233 int vcd_set_private_data_set_cb(vce_private_data_set_cb callback_func)
3235 SLOG(LOG_INFO, TAG_VCD, "[Server] Set private data set cb");
3238 ret = vcd_engine_agent_set_private_data_set_cb(callback_func);
3240 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set private data set cb : ret(%d)", ret);
3246 int vcd_set_private_data_requested_cb(vce_private_data_requested_cb callback_func)
3248 SLOG(LOG_INFO, TAG_VCD, "[Server] Set private data requested cb");
3251 ret = vcd_engine_agent_set_private_data_requested_cb(callback_func);
3253 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set private data requested cb : ret(%d)", ret);
3259 int vcd_set_nlu_base_info_requested_cb(vce_nlu_base_info_requested_cb callback_func)
3261 SLOG(LOG_INFO, TAG_VCD, "[Server] Set nlu base info requested cb");
3264 ret = vcd_engine_agent_set_nlu_base_info_requested_cb(callback_func);
3266 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set nlu base info requested cb : ret(%d)", ret);
3272 int vcd_set_specific_engine_request_cb(vce_specific_engine_request_cb callback_func)
3274 SLOG(LOG_INFO, TAG_VCD, "[Server] Set specific engine request cb");
3276 ret = vcd_engine_agent_set_specific_engine_request_cb(callback_func);
3278 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set specific engine request cb : ret(%d)", ret);
3284 int vcd_set_request_tts_cb(vce_request_tts_cb callback_func, void* user_data)
3286 SLOG(LOG_INFO, TAG_VCD, "[Server] Set request tts cb");
3288 ret = vcd_engine_agent_set_request_tts_cb(callback_func, user_data);
3290 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set request tts cb : ret(%d)", ret);
3296 int vcd_set_cancel_tts_cb(vce_cancel_tts_cb callback_func, void* user_data)
3298 SLOG(LOG_INFO, TAG_VCD, "[Server] Set cancel tts cb");
3300 ret = vcd_engine_agent_set_cancel_tts_cb(callback_func, user_data);
3302 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set cancel tts cb : ret(%d)", ret);
3308 int vcd_set_tts_audio_format_request_cb(vce_tts_audio_format_request_cb callback_func, void* user_data)
3310 SLOG(LOG_INFO, TAG_VCD, "[Server] Set tts audio format request cb");
3312 ret = vcd_engine_agent_set_get_tts_audio_format_cb(callback_func, user_data);
3314 SLOG(LOG_ERROR, TAG_VCD, "[Server ERROR] Fail to set tts audio format request : ret(%d)", ret);