changed operation string
[framework/appfw/alarm-manager.git] / include / alarm-internal.h
1 /*
2  *  alarm-manager
3  *
4  * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
5  *
6  * Contact: Venkatesha Sarpangala <sarpangala.v@samsung.com>, Jayoun Lee <airjany@samsung.com>,
7  * Sewook Park <sewook7.park@samsung.com>, Jaeho Lee <jaeho81.lee@samsung.com>
8  *
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
12  *
13  * http://www.apache.org/licenses/LICENSE-2.0
14  *
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.
20  *
21  */
22
23
24
25
26 #ifndef _ALARM_INTERNAL_H
27 #define _ALARM_INTERNAL_H
28
29 #define MAX_SNOOZE_CNT 5
30 #define REPEAT_MODE_ONCE 0x80
31
32 #define SIG_TIMER 0x32
33 #define ALARM_INFO_MAX 100
34
35 #include "alarm.h"
36 #include <dbus/dbus-glib.h>
37 #include <glib.h>
38 #include <dlog.h>
39 #include <bundle.h>
40 #include <appsvc.h>
41
42 #define INIT_ALARM_LIST_SIZE 64
43 #define INIT_SCHEDULED_ALARM_LIST_SIZE 32
44 #define MAX_BUNDLE_NAME_LEN 2048
45 #define MAX_SERVICE_NAME_LEN 256
46 #define MAX_PKG_NAME_LEN MAX_SERVICE_NAME_LEN-8
47
48 #define SYSTEM_TIME_CHANGED "setting_time_changed"
49
50 #ifdef LOG_TAG
51 #undef LOG_TAG
52 #endif
53 #define LOG_TAG "ALARM_MANAGER"
54
55 /*Application ID for native application which is not launched by application 
56 server.*/
57 #define ALARM_NATIVE_APP_ID 99999
58 /*  Application Instance ID for native application which is not launched by 
59 application server.*/
60 #define ALARM_NATIVE_APP_INST_ID 99999
61 /*  Prefix of dbus service name of native application.*/
62 #define ALARM_NATIVE_APP_DBUS_SVC_NAME_PREFIX "NATIVE"
63
64 /* how to send expire event : gproxy or low level dbus
65 * if you want to use gproxy for receiving expire_event, please enable 
66 * _EXPIRE_ALARM_INTERFACE_IS_DBUS_GPROXY_ feature
67 * otherwise, lowlevel dbus interface will be used for receiving expire_event.
68 * Now we use low level dbus instead of gproxy
69 */
70 /*#define       _EXPIRE_ALARM_INTERFACE_IS_DBUS_GPROXY_ */
71
72 typedef struct {
73         DBusGConnection *bus;
74         DBusGProxy *proxy;
75         alarm_cb_t alarm_handler;
76         void *user_param;
77         int pid;                /* this specifies pid*/
78         GQuark quark_app_service_name;  /*dbus_service_name is converted 
79          to quark value*/
80          GQuark quark_app_service_name_mod;
81 } alarm_context_t;
82
83 typedef union {
84         int day_of_week;                        /**< days of a week */
85         time_t interval;
86 } alarm_interval_u;
87
88 /**
89 * This struct has mode of an alarm
90 */
91 typedef struct {
92         alarm_interval_u u_interval;
93         alarm_repeat_mode_t repeat;     /**< repeat mode */
94 } alarm_mode_t;
95
96 /**
97 *  This enumeration has alarm type
98
99 typedef enum
100 {
101         ALARM_TYPE_DEFAULT = 0x0,       
102         ALARM_TYPE_RELATIVE = 0x01,     
103         ALARM_TYPE_VOLATILE = 0x02,     
104 }alarm_type_t;
105 */
106 #define ALARM_TYPE_RELATIVE             0x80000000      /**< relative  */
107
108 /**
109 * This struct has the information of an alarm
110 */
111
112 typedef struct {
113         alarm_date_t start; /**< start time of the alarm */
114         alarm_date_t end;   /**< end time of the alarm */
115         alarm_mode_t mode;      /**< mode of alarm */
116         int alarm_type;     /**< alarm type*/
117         int reserved_info;
118 } alarm_info_t;
119
120 bool _send_alarm_create(alarm_context_t context, alarm_info_t *alarm,
121                          alarm_id_t *id, const char *dst_service_name,const char *dst_service_name_mod,
122                          int *error_code);
123 bool _send_alarm_create_appsvc(alarm_context_t context, alarm_info_t *alarm_info,
124                         alarm_id_t *alarm_id, bundle *b,int *error_code);
125 bool _send_alarm_update(alarm_context_t context, int pid, alarm_id_t alarm_id,
126                          alarm_info_t *alarm_info, int *error_code);
127 bool _send_alarm_delete(alarm_context_t context, alarm_id_t alarm_id,
128                          int *error_code);
129 bool _send_alarm_get_list_of_ids(alarm_context_t context, int maxnum_of_ids,
130                                   alarm_id_t *alarm_id, int *num_of_ids,
131                                   int *error_code);
132 bool _send_alarm_get_number_of_ids(alarm_context_t context, int *num_of_ids,
133                                     int *error_code);
134 bool _send_alarm_get_info(alarm_context_t context, alarm_id_t alarm_id,
135                            alarm_info_t *alarm_info, int *error_code);
136 bool _send_alarm_reset(alarm_context_t context, int *error_code);
137
138 bool _send_alarm_power_on(alarm_context_t context, bool on_off,
139                            int *error_code);
140 bool _send_alarm_check_next_duetime(alarm_context_t context, int *error_code);
141 bool _send_alarm_power_off(alarm_context_t context, int *error_code);
142 bool _remove_from_scheduled_alarm_list(int pid, alarm_id_t alarm_id);
143 bool _load_alarms_from_registry();
144 bool _alarm_find_mintime_power_on(time_t *min_time);
145 bundle *_send_alarm_get_appsvc_info(alarm_context_t context, alarm_id_t alarm_id, int *error_code);
146 bool _send_alarm_set_rtc_time(alarm_context_t context, alarm_date_t *time, int *error_code);
147
148 /*  alarm manager*/
149 typedef struct {
150         time_t start;
151         time_t end;
152
153         int alarm_id;
154         int pid;
155         GQuark quark_app_unique_name;   /*the fullpath of application's pid is
156                 converted to quark value.*/
157         GQuark quark_app_service_name;  /*dbus_service_name is converted  to
158                 quark value.app_service_name is a service name  of application
159                 that creates alarm_info.*/
160         GQuark quark_app_service_name_mod;
161         GQuark quark_dst_service_name;  /*dbus_service_name is converted to 
162                 quark value.app_service_name is a service name  for 
163                 dst_service_name of alarm_create_extend().*/
164         GQuark quark_dst_service_name_mod;
165         time_t due_time;
166
167         GQuark quark_bundle;    /*Bundle Content containing app-svc info*/
168
169         alarm_info_t alarm_info;
170
171 } __alarm_info_t;
172
173 typedef struct {
174         bool used;
175         __alarm_info_t *__alarm_info;
176 } __alarm_entry_t;
177
178 typedef struct {
179         timer_t timer;
180         time_t c_due_time;
181         GSList *alarms;
182         int gmt_idx;
183         int dst;
184         DBusGConnection *bus;
185 } __alarm_server_context_t;
186
187 typedef struct {
188         bool used;
189         alarm_id_t alarm_id;
190         int pid;
191         __alarm_info_t *__alarm_info;
192 } __scheduled_alarm_t;
193
194 typedef struct {
195         char service_name[MAX_SERVICE_NAME_LEN];
196         alarm_id_t alarm_id;
197 } __expired_alarm_t;
198
199 time_t _alarm_next_duetime(__alarm_info_t *alarm_info);
200 bool _alarm_schedule();
201 bool _clear_scheduled_alarm_list();
202 bool _add_to_scheduled_alarm_list(__alarm_info_t *__alarm_info);
203
204 bool _save_alarms(__alarm_info_t *__alarm_info);
205 bool _delete_alarms(alarm_id_t alarm_id);
206 bool _update_alarms(__alarm_info_t *__alarm_info);
207
208 timer_t _alarm_create_timer();
209 bool _alarm_destory_timer(timer_t timer);
210 bool _alarm_set_timer(__alarm_server_context_t *alarm_context, timer_t timer,
211                        time_t due_time, alarm_id_t id);
212 bool _alarm_disable_timer(__alarm_server_context_t alarm_context);
213 bool _init_scheduled_alarm_list();
214
215 int _set_rtc_time(time_t _time);
216 int _set_sys_time(time_t _time);
217 int _set_time(time_t _time);
218
219
220 #ifdef _DEBUG_MODE_
221 #define ALARM_MGR_LOG_PRINT(FMT, ARG...)  do { printf("%5d", getpid()); printf
222         ("%s() : "FMT"\n", __FUNCTION__, ##ARG); } while (false)
223 #define ALARM_MGR_EXCEPTION_PRINT(FMT, ARG...)  do { printf("%5d", getpid()); 
224         printf("%s() : "FMT"\n", __FUNCTION__, ##ARG); } while (false)
225 #define ALARM_MGR_ASSERT_PRINT(FMT, ARG...) do { printf("%5d", getpid()); printf
226         ("%s() : "FMT"\n", __FUNCTION__, ##ARG); } while (false)
227 #else
228 #define ALARM_MGR_LOG_PRINT(FMT, ARG...) SLOGD(FMT, ##ARG);
229 #define ALARM_MGR_EXCEPTION_PRINT(FMT, ARG...) SLOGW(FMT, ##ARG);
230 #define ALARM_MGR_ASSERT_PRINT(FMT, ARG...) SLOGE(FMT, ##ARG);
231 #endif
232
233 /* int alarmmgr_check_next_duetime();*/
234
235
236 #endif /*_ALARM_INTERNAL_H*/