4 * Copyright (c) 2010-2013 Samsung Electronics Co., Ltd. All rights reserved.
6 * Contact: Youngae Kang <youngae.kang@samsung.com>, Minjune Kim <sena06.kim@samsung.com>
7 * Genie Kim <daejins.kim@samsung.com>
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
28 #include <sys/types.h>
33 #include "location-common-util.h"
34 #include "location-setting.h"
35 #include "location-log.h"
36 #include <app_manager.h>
37 #include <system_info.h>
40 int location_application_get_authority(void)
42 return LOCATION_APP_ON;
45 int location_application_set_authority(int auth)
47 return LOCATION_ERROR_NONE;
50 static gint compare_position(gconstpointer a, gconstpointer b)
52 g_return_val_if_fail(a, 1);
53 g_return_val_if_fail(b, -1);
55 if (location_position_equal((LocationPosition *) a, (LocationPosition *)b) == TRUE)
62 boundary_compare(gconstpointer comp1, gconstpointer comp2)
64 g_return_val_if_fail(comp1, 1);
65 g_return_val_if_fail(comp2, -1);
69 LocationBoundaryPrivate *priv1 = (LocationBoundaryPrivate *)comp1;
70 LocationBoundaryPrivate *priv2 = (LocationBoundaryPrivate *)comp2;
72 if (priv1->boundary->type == priv2->boundary->type) {
73 switch (priv1->boundary->type) {
74 case LOCATION_BOUNDARY_CIRCLE: {
75 if (location_position_equal(priv1->boundary->circle.center, priv2->boundary->circle.center)
76 && priv1->boundary->circle.radius == priv2->boundary->circle.radius) {
81 case LOCATION_BOUNDARY_RECT: {
82 if (location_position_equal(priv1->boundary->rect.left_top, priv2->boundary->rect.left_top)
83 && location_position_equal(priv1->boundary->rect.right_bottom, priv2->boundary->rect.right_bottom)) {
88 case LOCATION_BOUNDARY_POLYGON: {
89 GList *boundary1_next = NULL;
90 GList *boundary2_start = NULL, *boundary2_prev = NULL, *boundary2_next = NULL;
91 if (g_list_length(priv1->boundary->polygon.position_list) != g_list_length(priv2->boundary->polygon.position_list))
94 /* Find a matching index of Boundary2 with Boundary1's 1st postion. */
95 boundary2_start = g_list_find_custom(priv2->boundary->polygon.position_list, g_list_nth_data(priv1->boundary->polygon.position_list, 0), (GCompareFunc) compare_position);
96 if (boundary2_start == NULL) return -1;
98 boundary2_prev = g_list_previous(boundary2_start);
99 boundary2_next = g_list_next(boundary2_start);
100 if (boundary2_prev == NULL)
101 boundary2_prev = g_list_last(priv2->boundary->polygon.position_list);
103 if (boundary2_next == NULL)
104 boundary2_next = g_list_first(priv2->boundary->polygon.position_list);
106 boundary1_next = g_list_next(priv1->boundary->polygon.position_list);
107 if (boundary1_next && location_position_equal((LocationPosition *)boundary1_next->data, (LocationPosition *)boundary2_prev->data) == TRUE) {
108 boundary1_next = g_list_next(boundary1_next);
109 while (boundary1_next) {
110 boundary2_prev = g_list_previous(boundary2_prev);
111 if (boundary2_prev == NULL)
112 boundary2_prev = g_list_last(priv2->boundary->polygon.position_list);
114 if (location_position_equal((LocationPosition *)boundary1_next->data, (LocationPosition *) boundary2_prev->data) == FALSE)
117 boundary1_next = g_list_next(boundary1_next);
120 } else if (boundary1_next && location_position_equal((LocationPosition *)boundary1_next->data, (LocationPosition *)boundary2_next->data) == TRUE) {
121 boundary1_next = g_list_next(boundary1_next);
122 while (boundary1_next) {
123 boundary2_next = g_list_next(boundary2_next);
124 if (boundary2_next == NULL)
125 boundary2_next = g_list_first(priv2->boundary->polygon.position_list);
127 if (location_position_equal((LocationPosition *)boundary1_next->data, (LocationPosition *) boundary2_next->data) == FALSE)
130 boundary1_next = g_list_next(boundary1_next);
149 int set_prop_boundary(GList **prev_boundary_priv_list, GList *new_boundary_priv_list)
152 g_return_val_if_fail(new_boundary_priv_list, LOCATION_ERROR_PARAMETER);
155 GList *check_list = NULL;
157 LocationBoundaryPrivate *new_priv = NULL;
159 while ((new_priv = (LocationBoundaryPrivate *) g_list_nth_data(new_boundary_priv_list, index)) != NULL) {
160 *prev_boundary_priv_list = g_list_first(*prev_boundary_priv_list);
161 check_list = g_list_find_custom(*prev_boundary_priv_list, new_priv, (GCompareFunc)boundary_compare);
162 if (check_list == NULL) {
163 LocationBoundaryPrivate *copy_priv = g_slice_new0(LocationBoundaryPrivate);
164 if (!copy_priv) break;
165 copy_priv->boundary = location_boundary_copy(new_priv->boundary);
166 if (!copy_priv->boundary) break;
167 copy_priv->zone_status = new_priv->zone_status;
168 *prev_boundary_priv_list = g_list_append(*prev_boundary_priv_list, copy_priv);
170 LOCATION_LOGD("copy_priv: %p, copy_priv->boundary: %p, copy_priv->boundary->type: %d", copy_priv, copy_priv->boundary, copy_priv->boundary->type);
172 location_boundary_free(new_priv->boundary);
176 return LOCATION_ERROR_NONE;
179 int set_prop_removal_boundary(GList **prev_boundary_list, LocationBoundary *boundary)
182 g_return_val_if_fail(*prev_boundary_list, LOCATION_ERROR_PARAMETER);
184 GList *check_list = NULL;
185 LocationBoundaryPrivate *remove_priv = g_slice_new0(LocationBoundaryPrivate);
186 g_return_val_if_fail(remove_priv, LOCATION_ERROR_PARAMETER);
188 remove_priv->boundary = location_boundary_copy(boundary);
189 g_return_val_if_fail(remove_priv->boundary, LOCATION_ERROR_PARAMETER);
191 check_list = g_list_find_custom(*prev_boundary_list, remove_priv, (GCompareFunc) boundary_compare);
193 LOCATION_LOGD("Found");
194 *prev_boundary_list = g_list_delete_link(*prev_boundary_list, check_list);
197 if (g_list_length(*prev_boundary_list) == 0) {
198 LOCATION_LOGD("Boundary List is empty");
199 g_list_free(*prev_boundary_list);
200 *prev_boundary_list = NULL;
203 location_boundary_free(remove_priv->boundary);
204 g_slice_free(LocationBoundaryPrivate, remove_priv);
206 LOCATION_LOGD("EXIT <<<");
207 return LOCATION_ERROR_NONE;
210 void free_boundary_list(gpointer data)
212 LocationBoundaryPrivate *priv = (LocationBoundaryPrivate *)data;
214 location_boundary_free(priv->boundary);
215 g_slice_free(LocationBoundaryPrivate, priv);
218 int location_get_app_type(char *target_app_id)
226 if (target_app_id == NULL) {
228 ret = app_manager_get_app_id(pid, &app_id);
229 LOC_COND_RET(ret != APP_MANAGER_ERROR_NONE, LOCATION_ERROR_NONE, _E, "Fail to get app_id. Err[%d]", ret);
231 app_id = g_strdup(target_app_id);
234 ret = app_info_create(app_id, &app_info);
235 if (ret != APP_MANAGER_ERROR_NONE) {
236 LOCATION_LOGE("Fail to get app_info. Err[%d]", ret);
238 return LOCATION_ERROR_NONE;
241 ret = app_info_get_type(app_info, &type);
242 if (ret != APP_MANAGER_ERROR_NONE) {
243 LOCATION_LOGE("Fail to get type. Err[%d]", ret);
245 app_info_destroy(app_info);
246 return LOCATION_ERROR_NONE;
249 if (strcmp(type, "c++app") == 0)
251 else if (strcmp(type, "webapp") == 0)
258 app_info_destroy(app_info);
263 const char* err_msg(int err)
266 case LOCATION_ERROR_NONE: return "LOCATION_ERROR_NONE";
267 case LOCATION_ERROR_NOT_ALLOWED: return "LOCATION_ERROR_NOT_ALLOWED";
268 case LOCATION_ERROR_NOT_AVAILABLE: return "LOCATION_ERROR_NOT_AVAILABLE";
269 case LOCATION_ERROR_NETWORK_FAILED: return "LOCATION_ERROR_NETWORK_FAILED";
270 case LOCATION_ERROR_NETWORK_NOT_CONNECTED: return "LOCATION_ERROR_NETWORK_NOT_CONNECTED";
271 case LOCATION_ERROR_CONFIGURATION: return "LOCATION_ERROR_CONFIGURATION";
272 case LOCATION_ERROR_PARAMETER: return "LOCATION_ERROR_PARAMETER";
273 case LOCATION_ERROR_NOT_FOUND: return "LOCATION_ERROR_NOT_FOUND";
274 case LOCATION_ERROR_NOT_SUPPORTED: return "LOCATION_ERROR_NOT_SUPPORTED";
275 case LOCATION_ERROR_UNKNOWN: return "LOCATION_ERROR_UNKNOWN";
276 case LOCATION_ERROR_SETTING_OFF: return "LOCATION_ERROR_SETTING_OFF";
277 case LOCATION_ERROR_SECURITY_DENIED: return "LOCATION_ERROR_SECURITY_DENIED";
278 default: return "LOCATION_ERROR_UNKNOWN";
282 tizen_profile_t _get_tizen_profile()
284 static tizen_profile_t profile = TIZEN_PROFILE_UNKNOWN;
285 if (__builtin_expect(profile != TIZEN_PROFILE_UNKNOWN, 1))
289 system_info_get_platform_string("http://tizen.org/feature/profile", &profileName);
290 switch (*profileName) {
293 profile = TIZEN_PROFILE_MOBILE;
297 profile = TIZEN_PROFILE_WEARABLE;
301 profile = TIZEN_PROFILE_TV;
305 profile = TIZEN_PROFILE_IVI;
307 default: // common or unknown ==> ALL ARE COMMON.
308 profile = TIZEN_PROFILE_COMMON;