2 * Copyright (c) 2016 - 2017 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.
22 #include <pkgmgr-info.h>
23 #include <package_manager.h>
25 #include "badge_setting.h"
26 #include "badge_setting_service.h"
28 #include "badge_error.h"
29 #include "badge_log.h"
31 #define BADGE_PRIVILEGE "http://tizen.org/privilege/notification"
38 static bool _get_table_field_data_int(char **table, int *buf, int index)
40 if (table == NULL || buf == NULL || index < 0) {
42 ERR("table[%p], buf[%p], index[%d]", table, buf, index);
47 if (table[index] != NULL) {
48 *buf = atoi(table[index]);
58 static bool _get_table_field_data_string(char **table, char **buf, int ucs2, int index)
64 if (table == NULL || buf == NULL || index < 0) {
66 ERR("table[%p], buf[%p], index[%d]", table, buf, index);
73 *buf = NULL; /* LCOV_EXCL_LINE */
77 *buf = (char *)malloc(sLen + 1);
79 ERR("malloc is failed"); /* LCOV_EXCL_LINE */
82 memset(*buf, 0, sLen + 1);
83 strncpy(*buf, pTemp, sLen);
85 *buf = NULL; /* LCOV_EXCL_LINE */
95 EXPORT_API int badge_db_get_setting_by_appid(const char *appid, badge_setting_h *setting, uid_t uid)
97 int ret = BADGE_ERROR_NONE;
102 char *sql_query = NULL;
103 char **query_result = NULL;
104 badge_setting_h result_setting;
108 return BADGE_ERROR_INVALID_PARAMETER;
110 sql_ret = db_util_open(BADGE_DB_PATH, &db, 0);
111 if (sql_ret != SQLITE_OK || db == NULL) {
112 ERR("Failed db util open [%s][%d]", BADGE_DB_PATH, sql_ret);
113 return BADGE_ERROR_FROM_DB;
116 sql_query = sqlite3_mprintf("SELECT pkgname, appid, allow_to_display FROM %s " \
117 "WHERE appid = %Q AND (uid = %d OR uid = %d) " \
118 "ORDER BY uid DESC;",
119 BADGE_SETTING_DB_TABLE, appid, uid, tzplatform_getuid(TZ_SYS_GLOBALAPP_USER));
121 ERR("Failed to alloc query");
122 ret = BADGE_ERROR_FROM_DB;
126 sql_ret = sqlite3_get_table(db, sql_query, &query_result, &row_count, &col_count, NULL);
127 if (sql_ret != SQLITE_OK && sql_ret != -1) {
128 ERR("sqlite3_get_table failed [%d][%s]", sql_ret,
130 ret = BADGE_ERROR_FROM_DB;
135 DBG("No setting found for [%s]", appid);
136 ret = BADGE_ERROR_NOT_EXIST;
140 result_setting = (struct badge_setting *)malloc(sizeof(struct badge_setting));
141 if (result_setting == NULL) {
142 ERR("Failed to alloc setting");
143 ret = BADGE_ERROR_OUT_OF_MEMORY;
147 col_index = col_count;
149 _get_table_field_data_string(query_result, &(result_setting[0].pkgname), 1, col_index++);
150 _get_table_field_data_string(query_result, &(result_setting[0].appid), 1, col_index++);
151 _get_table_field_data_int(query_result, (int *)&(result_setting[0].allow_to_display), col_index++);
153 *setting = result_setting;
157 sqlite3_free_table(query_result);
159 sqlite3_free(sql_query);
161 sql_ret = db_util_close(db);
162 if (sql_ret != SQLITE_OK)
163 WARN("Failed to db_util_close");
169 EXPORT_API int badge_db_update_setting(char *pkgname, char *appid, int allow_to_display, uid_t uid)
171 int ret = BADGE_ERROR_NONE;
176 if (pkgname == NULL || appid == NULL) {
177 ERR("Invalid package name or app id");
178 return BADGE_ERROR_INVALID_PARAMETER;
181 sql_ret = db_util_open(BADGE_DB_PATH, &db, 0);
182 if (sql_ret != SQLITE_OK || db == NULL) {
183 ERR("db_util_open failed [%s][%d]", BADGE_DB_PATH, sql_ret);
184 return BADGE_ERROR_FROM_DB;
187 sqlbuf = sqlite3_mprintf("UPDATE %s SET allow_to_display = %d " \
188 "WHERE pkgname = %Q AND appid = %Q " \
190 BADGE_SETTING_DB_TABLE, allow_to_display,
191 pkgname, appid, uid);
194 ERR("Failed to alloc query");
195 ret = BADGE_ERROR_FROM_DB;
199 ret = badge_db_exec(db, sqlbuf, NULL);
203 sqlite3_free(sqlbuf);
205 sql_ret = db_util_close(db);
206 if (sql_ret != SQLITE_OK)
207 WARN("Failed to db_util_close");
213 EXPORT_API int badge_db_get_allow_to_display_by_appid(char *appid, int *allow_to_display, uid_t uid)
215 int ret = BADGE_ERROR_NONE;
220 char *sql_query = NULL;
221 char **query_result = NULL;
225 return BADGE_ERROR_INVALID_PARAMETER;
227 sql_ret = db_util_open(BADGE_DB_PATH, &db, 0);
228 if (sql_ret != SQLITE_OK || db == NULL) {
229 ERR("Failed db util open [%s][%d]", BADGE_DB_PATH, sql_ret);
230 return BADGE_ERROR_FROM_DB;
233 sql_query = sqlite3_mprintf("SELECT allow_to_display FROM %s WHERE appid = %Q " \
234 "AND (uid = %d OR uid = %d) ORDER BY uid DESC;",
235 BADGE_SETTING_DB_TABLE, appid, uid,
236 tzplatform_getuid(TZ_SYS_GLOBALAPP_USER));
238 ERR("Failed to alloc query");
239 ret = BADGE_ERROR_FROM_DB;
243 sql_ret = sqlite3_get_table(db, sql_query, &query_result, &row_count, &col_count, NULL);
244 if (sql_ret != SQLITE_OK && sql_ret != -1) {
245 ERR("sqlite3_get_table failed [%d][%s]", sql_ret,
247 ret = BADGE_ERROR_FROM_DB;
252 DBG("No setting found for [%s]", appid);
253 ret = BADGE_ERROR_NOT_EXIST;
257 col_index = col_count;
259 _get_table_field_data_int(query_result, (int *)allow_to_display, col_index++);
263 sqlite3_free_table(query_result);
265 sqlite3_free(sql_query);
267 sql_ret = db_util_close(db);
268 if (sql_ret != SQLITE_OK)
269 WARN("Failed to db_util_close");
275 static bool _is_package_in_setting_table(sqlite3 *db, const char *pkgname, const char* appid, uid_t uid)
277 sqlite3_stmt *db_statement = NULL;
278 int sqlite3_ret = SQLITE_OK;
283 sqlite3_ret = sqlite3_prepare_v2(db, "SELECT appid FROM badge_setting WHERE uid = ? AND pkgname = ? AND appid = ?", -1, &db_statement, NULL);
285 sqlite3_ret = sqlite3_prepare_v2(db, "SELECT pkgname FROM badge_setting WHERE uid = ? AND pkgname = ?", -1, &db_statement, NULL);
287 if (sqlite3_ret != SQLITE_OK) {
288 ERR("sqlite3_prepare_v2 failed [%d][%s]", sqlite3_ret,
294 sqlite3_bind_int(db_statement, field_index++, uid);
295 sqlite3_bind_text(db_statement, field_index++, pkgname, -1, SQLITE_TRANSIENT);
297 sqlite3_bind_text(db_statement, field_index++, appid, -1, SQLITE_TRANSIENT);
299 sqlite3_ret = sqlite3_step(db_statement);
300 if (sqlite3_ret == SQLITE_DONE) {
301 INFO("no matched appid from pkgname found[%s][%s][%d]", pkgname, appid, sqlite3_ret);
306 if (sqlite3_ret != SQLITE_OK && sqlite3_ret != SQLITE_ROW) {
307 ERR("sqlite3_step failed [%d][%s]", sqlite3_ret,
315 sqlite3_finalize(db_statement);
320 static int app_info_callback(const pkgmgrinfo_appinfo_h handle, void *user_data)
322 badge_setting_info *info = (badge_setting_info *)user_data;
323 sqlite3 *db = info->db;
324 sqlite3_stmt *db_statement = NULL;
325 int pkgmgr_ret = PACKAGE_MANAGER_ERROR_NONE;
327 int sqlite3_ret = SQLITE_OK;
329 char *pkgname = NULL;
331 pkgmgr_ret = pkgmgrinfo_appinfo_get_appid(handle, &appid);
332 if (pkgmgr_ret != PACKAGE_MANAGER_ERROR_NONE) {
333 ERR("pkgmgrinfo_appinfo_get_appid failed [%d]", pkgmgr_ret);
337 pkgmgr_ret = pkgmgrinfo_appinfo_get_pkgname(handle, &pkgname);
338 if (pkgmgr_ret != PACKAGE_MANAGER_ERROR_NONE) {
339 ERR("pkgmgrinfo_appinfo_get_pkgname failed [%d]", pkgmgr_ret);
343 if (_is_package_in_setting_table(db, pkgname, appid, info->uid) == true) {
344 INFO("uid %d [%s] is exist", info->uid, appid);
348 INFO("uid %d pkgname %s [%s] will be inserted", info->uid, pkgname, appid);
349 sqlite3_ret = sqlite3_prepare_v2(db, "INSERT INTO badge_setting (uid, pkgname, appid) "
350 "VALUES (?, ?, ?) ", -1, &db_statement, NULL);
352 if (sqlite3_ret != SQLITE_OK) {
353 ERR("sqlite3_prepare_v2 failed [%d][%s]", sqlite3_ret,
358 sqlite3_bind_int(db_statement, field_index++, info->uid);
359 sqlite3_bind_text(db_statement, field_index++, pkgname, -1, SQLITE_TRANSIENT);
360 sqlite3_bind_text(db_statement, field_index++, appid, -1, SQLITE_TRANSIENT);
362 sqlite3_ret = sqlite3_step(db_statement);
364 INFO("sqlite3_step returns[%d]", sqlite3_ret);
366 if (sqlite3_ret != SQLITE_OK && sqlite3_ret != SQLITE_DONE)
367 ERR("sqlite3_step failed [%d][%s]", sqlite3_ret,
372 sqlite3_finalize(db_statement);
377 static int package_info_callback(const pkgmgrinfo_pkginfo_h package_info, void *user_data)
379 char *pkgname = NULL;
380 int pkgmgr_ret = PACKAGE_MANAGER_ERROR_NONE;
381 pkgmgrinfo_appinfo_filter_h handle = NULL;
382 badge_setting_info *info = (badge_setting_info *)user_data;
384 pkgmgr_ret = pkgmgrinfo_pkginfo_get_pkgname(package_info, &pkgname);
385 if (pkgmgr_ret != PACKAGE_MANAGER_ERROR_NONE) {
386 ERR("package_info_get_package failed [%d]", pkgmgr_ret);
390 pkgmgr_ret = pkgmgrinfo_appinfo_filter_create(&handle);
391 if (pkgmgr_ret != PMINFO_R_OK) {
392 ERR("pkgmgrinfo_appinfo_filter_create failed [%d]", pkgmgr_ret);
396 pkgmgr_ret = pkgmgrinfo_appinfo_filter_add_string(handle, PMINFO_APPINFO_PROP_APP_PACKAGE, pkgname);
397 if (pkgmgr_ret != PMINFO_R_OK) {
398 ERR("pkgmgrinfo_appinfo_filter_add_string failed [%d]",
403 pkgmgr_ret = pkgmgrinfo_appinfo_filter_add_bool(handle, PMINFO_APPINFO_PROP_APP_NODISPLAY, false);
404 if (pkgmgr_ret != PMINFO_R_OK) {
405 ERR("pkgmgrinfo_appinfo_filter_add_bool failed [%d]",
410 pkgmgr_ret = pkgmgrinfo_appinfo_usr_filter_foreach_appinfo(handle, app_info_callback, info, info->uid);
411 if (pkgmgr_ret != PMINFO_R_OK) {
412 ERR("pkgmgrinfo_pkginfo_filter_foreach_appinfo failed [%d]",
419 pkgmgrinfo_appinfo_filter_destroy(handle);
424 EXPORT_API int badge_setting_insert_package_for_uid(const char *pkgname, uid_t uid)
427 int ret = BADGE_ERROR_NONE;
428 int sqlite3_ret = SQLITE_OK;
429 int pkgmgr_ret = PACKAGE_MANAGER_ERROR_NONE;
430 badge_setting_info info;
431 pkgmgrinfo_pkginfo_filter_h handle = NULL;
433 sqlite3_ret = sqlite3_open_v2(BADGE_DB_PATH, &db, SQLITE_OPEN_READWRITE, NULL);
434 if (sqlite3_ret != SQLITE_OK || db == NULL) {
435 ERR("db_util_open failed [%s][%d]", BADGE_DB_PATH, sqlite3_ret);
436 ret = BADGE_ERROR_FROM_DB;
440 sqlite3_exec(db, "BEGIN immediate;", NULL, NULL, NULL);
442 pkgmgr_ret = pkgmgrinfo_pkginfo_filter_create(&handle);
443 if (pkgmgr_ret != PMINFO_R_OK) {
444 ERR("pkgmgrinfo_pkginfo_filter_create failed [%d]", pkgmgr_ret);
445 ret = BADGE_ERROR_FROM_DB;
449 pkgmgr_ret = pkgmgrinfo_pkginfo_filter_add_string(handle, PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgname);
450 if (pkgmgr_ret != PMINFO_R_OK) {
451 ERR("pkgmgrinfo_pkginfo_filter_add_string failed [%d]",
453 ret = BADGE_ERROR_FROM_DB;
459 pkgmgr_ret = pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, package_info_callback, &info, uid);
460 if (pkgmgr_ret != PMINFO_R_OK) {
461 ERR("pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo failed [%d]",
463 ret = BADGE_ERROR_FROM_DB;
469 pkgmgrinfo_pkginfo_filter_destroy(handle);
471 if (ret == BADGE_ERROR_NONE)
472 sqlite3_exec(db, "END;", NULL, NULL, NULL);
474 sqlite3_exec(db, "ROLLBACK;", NULL, NULL, NULL);
476 if ((sqlite3_ret = db_util_close(db)) != SQLITE_OK)
477 WARN("db_util_close failed [%d]", sqlite3_ret);
483 EXPORT_API int badge_setting_delete_package_for_uid(const char *pkgname, uid_t uid)
486 sqlite3_stmt *db_statement = NULL;
487 int ret = BADGE_ERROR_NONE;
488 int sqlite3_ret = SQLITE_OK;
490 bool is_package_in_setting_table = false;
492 sqlite3_ret = sqlite3_open_v2(BADGE_DB_PATH, &db, SQLITE_OPEN_READWRITE, NULL);
493 if (sqlite3_ret != SQLITE_OK || db == NULL) {
494 ERR("db_util_open failed [%s][%d]", BADGE_DB_PATH, sqlite3_ret);
495 ret = BADGE_ERROR_FROM_DB;
499 is_package_in_setting_table = _is_package_in_setting_table(db, pkgname, NULL, uid);
500 if (is_package_in_setting_table == false) {
501 INFO("[%s] is not exist", pkgname);
505 sqlite3_exec(db, "BEGIN immediate;", NULL, NULL, NULL);
507 sqlite3_ret = sqlite3_prepare_v2(db, "DELETE FROM badge_setting WHERE uid = ? AND pkgname = ? ", -1, &db_statement, NULL);
508 if (sqlite3_ret != SQLITE_OK) {
509 ERR("sqlite3_prepare_v2 failed [%d][%s]", sqlite3_ret,
511 ret = BADGE_ERROR_FROM_DB;
515 sqlite3_bind_int(db_statement, field_index++, uid);
516 sqlite3_bind_text(db_statement, field_index++, pkgname, -1, SQLITE_TRANSIENT);
518 sqlite3_ret = sqlite3_step(db_statement);
519 if (sqlite3_ret != SQLITE_OK && sqlite3_ret != SQLITE_DONE) {
520 ERR("sqlite3_step failed [%d][%s]", sqlite3_ret,
522 ret = BADGE_ERROR_FROM_DB;
527 sqlite3_finalize(db_statement);
529 if (ret == BADGE_ERROR_NONE)
530 sqlite3_exec(db, "END;", NULL, NULL, NULL);
532 sqlite3_exec(db, "ROLLBACK;", NULL, NULL, NULL);
534 if ((sqlite3_ret = db_util_close(db)) != SQLITE_OK)
535 WARN("db_util_close failed [%d]", sqlite3_ret);
541 EXPORT_API int badge_setting_refresh_setting_table(uid_t uid)
543 int ret = BADGE_ERROR_NONE;
547 badge_setting_info info;
548 pkgmgrinfo_pkginfo_filter_h filter;
550 sql_ret = sqlite3_open_v2(BADGE_DB_PATH, &db, SQLITE_OPEN_READWRITE, NULL);
551 if (sql_ret != SQLITE_OK || db == NULL) {
552 ERR("sqlite3_open_v2 fail [%s][%d]", BADGE_DB_PATH, sql_ret);
553 return BADGE_ERROR_FROM_DB;
556 sqlite3_exec(db, "BEGIN immediate;", NULL, NULL, NULL);
558 pkgmgr_ret = pkgmgrinfo_pkginfo_filter_create(&filter);
559 if (pkgmgr_ret != PMINFO_R_OK) {
560 ERR("pkgmgrinfo_pkginfo_filter_create failed [%d]", pkgmgr_ret);
561 ret = BADGE_ERROR_FROM_DB;
567 pkgmgr_ret = pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(filter, package_info_callback, &info, uid);
568 if (pkgmgr_ret != PMINFO_R_OK) {
569 ERR("pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo failed [%d]",
571 ret = BADGE_ERROR_FROM_DB;
577 pkgmgrinfo_pkginfo_filter_destroy(filter);
579 if (ret == BADGE_ERROR_NONE)
580 sqlite3_exec(db, "END;", NULL, NULL, NULL);
582 sqlite3_exec(db, "ROLLBACK;", NULL, NULL, NULL);
583 if ((sql_ret = db_util_close(db)) != SQLITE_OK)
584 WARN("fail to db_util_close [%d]", sql_ret);