-#if 0
- if (hcamcorder->device_type == MM_VIDEO_DEVICE_NONE) {
- resource_fd = open(__MMCAMCORDER_PATH_RECORDER_RESOURCE, O_RDONLY);
- } else {
- resource_fd = open(__MMCAMCORDER_PATH_CAMERA_RESOURCE, O_RDONLY);
- }
-
- if (resource_fd < 0) {
- _mmcam_dbg_log("open error %s : cur %d",strerror(errno),errno);
- if(errno == EPERM || errno == EACCES) {
- ret = MM_ERROR_COMMON_INVALID_PERMISSION;
- } else {
- ret = MM_ERROR_CAMCORDER_INTERNAL;
- }
- goto _ERR_DEFAULT_VALUE_INIT;
- } else {
- close(resource_fd);
- resource_fd = -1;
- _mmcam_dbg_warn("permission check done");
- }
-#else
- {
- FILE *fp = NULL;;
- int length_read = 0;
- int priv_check = FALSE;
- uid_t my_uid = 0;
- char *client_session = "";
- char *smack_string = NULL;
- char uid_string[50];
- size_t buffer_length = 0;
- cynara *p_cynara = NULL;
-
- if (cynara_initialize(&p_cynara, NULL) != CYNARA_API_SUCCESS) {
- ret = MM_ERROR_CAMCORDER_INTERNAL;
- goto _ERR_DEFAULT_VALUE_INIT;
- }
-
- fp = fopen("/proc/self/attr/current", "r");
- if (fp == NULL) {
- ret = MM_ERROR_CAMCORDER_INTERNAL;
- goto _ERR_DEFAULT_VALUE_INIT;
- }
-
- length_read = getline(&smack_string, &buffer_length, fp);
- if (length_read > 0) {
- int cynara_ret = 0;
-
- my_uid = getuid();
- snprintf(uid_string, 50, "%d", my_uid);
- _mmcam_dbg_log("label %s, uid %u, %s", smack_string, my_uid, uid_string);
-
- if (hcamcorder->device_type == MM_VIDEO_DEVICE_NONE) {
- cynara_ret = cynara_check(p_cynara, smack_string, client_session, uid_string,
- "http://tizen.org/privilege/recorder");
- } else {
- cynara_ret = cynara_check(p_cynara, smack_string, client_session, uid_string,
- "http://tizen.org/privilege/camera");
- }
- if (cynara_ret == CYNARA_API_ACCESS_ALLOWED) {
- priv_check = TRUE;
- _mmcam_dbg_err("privilege check done");
- } else {
- ret = MM_ERROR_COMMON_INVALID_PERMISSION;
- _mmcam_dbg_err("permission denied");
- }
- } else {
- ret = MM_ERROR_CAMCORDER_INTERNAL;
- _mmcam_dbg_err("getline failed");
- }
-
- if (smack_string) {
- free(smack_string);
- smack_string = NULL;
- }
-
- fclose(fp);
- fp = NULL;
-
- cynara_finish(p_cynara);
- p_cynara = NULL;
-
- if (priv_check == FALSE) {
- goto _ERR_DEFAULT_VALUE_INIT;
- }
- }
-#endif
-
- /* Check session */
- if (MM_ERROR_NONE == _mm_session_util_read_information(-1, &hcamcorder->session_type, &hcamcorder->session_flags)) {
- _mmcam_dbg_log("use sound focus function.");
- hcamcorder->sound_focus_register = TRUE;
- } else {
- _mmcam_dbg_log("_mm_session_util_read_information failed. skip sound focus function.");
- hcamcorder->sound_focus_register = FALSE;
- }
-
- /* register sound focus */
- if (hcamcorder->sound_focus_register) {
- if (MM_ERROR_NONE != mm_sound_focus_get_id(&hcamcorder->sound_focus_id)) {
- _mmcam_dbg_err("mm_sound_focus_get_uniq failed");
- ret = MM_ERROR_POLICY_BLOCKED;
- goto _ERR_DEFAULT_VALUE_INIT;
- }
-
- if (MM_ERROR_NONE != mm_sound_register_focus_for_session(hcamcorder->sound_focus_id, "media", _mmcamcorder_sound_focus_cb, hcamcorder)) {
- _mmcam_dbg_err("mm_sound_register_focus failed");
- ret = MM_ERROR_POLICY_BLOCKED;
- goto _ERR_DEFAULT_VALUE_INIT;
- }
-
- _mmcam_dbg_log("mm_sound_register_focus done - id %d, session type %d, flags 0x%x",
- hcamcorder->sound_focus_id, hcamcorder->session_type, hcamcorder->session_flags);
- }