1 /* Evolution calendar ecal
3 * Copyright (C) 2001 Ximian, Inc.
5 * Authors: Federico Mena-Quintero <federico@ximian.com>
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of version 2 of the GNU General Public
9 * License as published by the Free Software Foundation.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
24 #include <glib-object.h>
25 #include <libedataserver/e-source.h>
26 #include <libecal/e-cal-recur.h>
27 #include <libecal/e-cal-util.h>
28 #include <libecal/e-cal-view.h>
29 #include <libecal/e-cal-types.h>
35 #define E_TYPE_CAL (e_cal_get_type ())
36 #define E_CAL(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), E_TYPE_CAL, ECal))
37 #define E_CAL_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), E_TYPE_CAL, ECalClass))
38 #define E_IS_CAL(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), E_TYPE_CAL))
39 #define E_IS_CAL_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), E_TYPE_CAL))
41 #define E_CAL_SET_MODE_STATUS_ENUM_TYPE (e_cal_set_mode_status_enum_get_type ())
42 #define CAL_MODE_ENUM_TYPE (cal_mode_enum_get_type ())
44 typedef struct _ECal ECal;
45 typedef struct _ECalClass ECalClass;
46 typedef struct _ECalPrivate ECalPrivate;
48 /* Set mode status for the e_cal_set_mode function */
50 E_CAL_SET_MODE_SUCCESS,
52 E_CAL_SET_MODE_NOT_SUPPORTED
55 /* Whether the ecal is not loaded, is being loaded, or is already loaded */
57 E_CAL_LOAD_NOT_LOADED,
58 E_CAL_LOAD_AUTHENTICATING,
71 GObjectClass parent_class;
73 /* Notification signals */
75 void (* cal_opened) (ECal *ecal, ECalendarStatus status);
76 void (* cal_set_mode) (ECal *ecal, ECalSetModeStatus status, CalMode mode);
78 void (* backend_error) (ECal *ecal, const char *message);
80 void (* categories_changed) (ECal *ecal, GPtrArray *categories);
82 void (* forget_password) (ECal *ecal, const char *key);
84 void (* backend_died) (ECal *ecal);
87 typedef char * (* ECalAuthFunc) (ECal *ecal,
92 GType e_cal_get_type (void);
94 GType e_cal_open_status_enum_get_type (void);
95 GType e_cal_set_mode_status_enum_get_type (void);
96 GType cal_mode_enum_get_type (void);
98 ECal *e_cal_new (ESource *source, CalObjType type);
99 ECal *e_cal_new_from_uri (const gchar *uri, CalObjType type);
101 void e_cal_set_auth_func (ECal *ecal, ECalAuthFunc func, gpointer data);
103 gboolean e_cal_open (ECal *ecal, gboolean only_if_exists, GError **error);
104 void e_cal_open_async (ECal *ecal, gboolean only_if_exists);
105 gboolean e_cal_remove_calendar (ECal *ecal, GError **error);
107 GList *e_cal_uri_list (ECal *ecal, CalMode mode);
109 ECalLoadState e_cal_get_load_state (ECal *ecal);
111 ESource *e_cal_get_source (ECal *ecal);
112 const char *e_cal_get_uri (ECal *ecal);
114 gboolean e_cal_is_read_only (ECal *ecal, gboolean *read_only, GError **error);
115 gboolean e_cal_get_cal_address (ECal *ecal, char **cal_address, GError **error);
116 gboolean e_cal_get_alarm_email_address (ECal *ecal, char **alarm_address, GError **error);
117 gboolean e_cal_get_ldap_attribute (ECal *ecal, char **ldap_attribute, GError **error);
119 gboolean e_cal_get_one_alarm_only (ECal *ecal);
120 gboolean e_cal_get_organizer_must_attend (ECal *ecal);
121 gboolean e_cal_get_save_schedules (ECal *ecal);
122 gboolean e_cal_get_static_capability (ECal *ecal, const char *cap);
124 gboolean e_cal_set_mode (ECal *ecal, CalMode mode);
126 gboolean e_cal_get_default_object (ECal *ecal,
127 icalcomponent **icalcomp, GError **error);
129 gboolean e_cal_get_object (ECal *ecal,
132 icalcomponent **icalcomp,
135 gboolean e_cal_get_changes (ECal *ecal, const char *change_id, GList **changes, GError **error);
136 void e_cal_free_change_list (GList *list);
138 gboolean e_cal_get_object_list (ECal *ecal, const char *query, GList **objects, GError **error);
139 gboolean e_cal_get_object_list_as_comp (ECal *ecal, const char *query, GList **objects, GError **error);
140 void e_cal_free_object_list (GList *objects);
142 gboolean e_cal_get_free_busy (ECal *ecal, GList *users, time_t start, time_t end,
143 GList **freebusy, GError **error);
145 void e_cal_generate_instances (ECal *ecal, CalObjType type,
146 time_t start, time_t end,
147 ECalRecurInstanceFn cb, gpointer cb_data);
149 GSList *e_cal_get_alarms_in_range (ECal *ecal, time_t start, time_t end);
151 void e_cal_free_alarms (GSList *comp_alarms);
153 gboolean e_cal_get_alarms_for_object (ECal *ecal, const char *uid,
154 time_t start, time_t end,
155 ECalComponentAlarms **alarms);
157 gboolean e_cal_create_object (ECal *ecal, icalcomponent *icalcomp, char **uid, GError **error);
158 gboolean e_cal_modify_object (ECal *ecal, icalcomponent *icalcomp, CalObjModType mod, GError **error);
159 gboolean e_cal_remove_object (ECal *ecal, const char *uid, GError **error);
160 gboolean e_cal_remove_object_with_mod (ECal *ecal, const char *uid, const char *rid, CalObjModType mod, GError **error);
162 gboolean e_cal_discard_alarm (ECal *ecal, ECalComponent *comp, const char *auid, GError **error);
164 gboolean e_cal_receive_objects (ECal *ecal, icalcomponent *icalcomp, GError **error);
165 gboolean e_cal_send_objects (ECal *ecal, icalcomponent *icalcomp, GError **error);
167 gboolean e_cal_get_timezone (ECal *ecal, const char *tzid, icaltimezone **zone, GError **error);
168 gboolean e_cal_add_timezone (ECal *ecal, icaltimezone *izone, GError **error);
169 /* Sets the default timezone to use to resolve DATE and floating DATE-TIME
170 values. This will typically be from the user's timezone setting. Call this
171 before using any other functions. It will pass the default timezone on to
172 the server. Returns TRUE on success. */
173 gboolean e_cal_set_default_timezone (ECal *ecal, icaltimezone *zone, GError **error);
175 gboolean e_cal_get_query (ECal *ecal, const char *sexp, ECalView **query, GError **error);
177 /* Resolves TZIDs for the recurrence generator. */
178 icaltimezone *e_cal_resolve_tzid_cb (const char *tzid, gpointer data);
180 /* Returns a complete VCALENDAR for a VEVENT/VTODO including all VTIMEZONEs
181 used by the component. It also includes a 'METHOD:PUBLISH' property. */
182 char* e_cal_get_component_as_string (ECal *ecal, icalcomponent *icalcomp);
184 const char * e_cal_get_error_message (ECalendarStatus status);