aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/corba-cal.c
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/corba-cal.c')
-rw-r--r--calendar/corba-cal.c209
1 files changed, 209 insertions, 0 deletions
diff --git a/calendar/corba-cal.c b/calendar/corba-cal.c
new file mode 100644
index 0000000000..d78685bf90
--- /dev/null
+++ b/calendar/corba-cal.c
@@ -0,0 +1,209 @@
+/*
+ * corba-cal.c: Service that provides access to the calendar repository
+ *
+ * Author:
+ * Miguel de Icaza (miguel@gnu.org)
+ */
+
+#include <config.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <sys/stat.h>
+#include "calendar.h"
+#include "gnome-cal.h"
+#include "alarm.h"
+#include "timeutil.h"
+#include "../libversit/vcc.h"
+#include <libgnorba/gnome-factory.h>
+#include "GnomeCal.h"
+#include "corba-cal-factory.h"
+#include "corba-cal.h"
+
+typedef struct {
+ POA_GNOME_Calendar_Repository servant;
+ GnomeCalendar *calendar;
+} CalendarServant;
+
+/*
+ * Vectors
+ */
+static POA_GNOME_Calendar_Repository__epv calendar_repository_epv;
+static POA_GNOME_Calendar_Repository__vepv calendar_repository_vepv;
+
+/*
+ * Servant and Object Factory
+ */
+static POA_GNOME_Calendar_Repository calendar_repository_servant;
+
+static inline GnomeCalendar *
+gnomecal_from_servant (PortableServer_Servant servant)
+{
+ CalendarServant *cs = (CalendarServant *) servant;
+
+ return cs->calendar;
+}
+
+static CORBA_char *
+cal_repo_get_object (PortableServer_Servant servant,
+ CORBA_char *uid,
+ CORBA_Environment *ev)
+{
+ GnomeCalendar *gcal = gnomecal_from_servant (servant);
+ iCalObject *obj;
+ char *buffer;
+ CORBA_char *ret;
+
+ obj = calendar_object_find_event (gcal->cal, uid);
+ if (obj == NULL){
+ CORBA_exception_set (
+ ev,
+ CORBA_USER_EXCEPTION,
+ ex_GNOME_Calendar_Repository_NotFound,
+ "");
+ return NULL;
+ }
+
+ buffer = calendar_string_from_object (obj);
+ ret = CORBA_string_dup (buffer);
+ free (buffer);
+
+ return ret;
+}
+
+static CORBA_char *
+cal_repo_get_object_by_pilot_id (PortableServer_Servant servant,
+ CORBA_long pilot_id,
+ CORBA_Environment *ev)
+{
+ GnomeCalendar *gcal = gnomecal_from_servant (servant);
+ iCalObject *obj;
+ char *buffer;
+ CORBA_char *ret;
+
+ obj = calendar_object_find_by_pilot (gcal->cal, pilot_id);
+ if (obj == NULL){
+ CORBA_exception_set (ev,
+ CORBA_USER_EXCEPTION,
+ ex_GNOME_Calendar_Repository_NotFound, "");
+ return NULL;
+ }
+
+ buffer = calendar_string_from_object (obj);
+ ret = CORBA_string_dup (buffer);
+ free (buffer);
+
+ return ret;
+
+}
+
+static CORBA_char *
+cal_repo_get_id_from_pilot_id (PortableServer_Servant servant,
+ CORBA_long pilot_id,
+ CORBA_Environment *ev)
+{
+ GnomeCalendar *gcal = gnomecal_from_servant (servant);
+ iCalObject *obj;
+
+ obj = calendar_object_find_by_pilot (gcal->cal, pilot_id);
+ if (obj == NULL){
+ CORBA_exception_set (ev,
+ CORBA_USER_EXCEPTION,
+ ex_GNOME_Calendar_Repository_NotFound, "");
+ return NULL;
+ }
+
+ return CORBA_string_dup (obj->uid);
+}
+
+static void
+cal_repo_delete_object (PortableServer_Servant servant,
+ CORBA_char *uid,
+ CORBA_Environment *ev)
+{
+ GnomeCalendar *gcal = gnomecal_from_servant (servant);
+ iCalObject *obj;
+
+ obj = calendar_object_find_event (gcal->cal, uid);
+ if (obj == NULL){
+ CORBA_exception_set (ev,
+ CORBA_USER_EXCEPTION,
+ ex_GNOME_Calendar_Repository_NotFound, NULL);
+ return;
+ }
+
+ gnome_calendar_remove_object (gcal, obj);
+}
+
+static void
+cal_repo_update_object (PortableServer_Servant servant,
+ CORBA_char *uid,
+ CORBA_char *vcalendar_object,
+ CORBA_Environment *ev)
+{
+ GnomeCalendar *gcal = gnomecal_from_servant (servant);
+ iCalObject *obj;
+ iCalObject *new_object;
+
+ new_object = ical_object_new_from_string (vcalendar_object);
+
+ obj = calendar_object_find_event (gcal->cal, uid);
+ if (obj != NULL){
+ calendar_remove_object (gcal->cal, obj);
+ }
+
+ calendar_add_object (gcal->cal, new_object);
+}
+
+static void
+cal_repo_done (PortableServer_Servant servant,
+ CORBA_Environment *ev)
+{
+ GnomeCalendar *gcal = gnomecal_from_servant (servant);
+
+ calendar_save (gcal->cal, NULL);
+}
+
+static void
+init_calendar_repo_class (void)
+{
+ calendar_repository_epv.get_object = cal_repo_get_object;
+ calendar_repository_epv.get_object_by_pilot_id = cal_repo_get_object_by_pilot_id;
+ calendar_repository_epv.get_id_from_pilot_id = cal_repo_get_id_from_pilot_id;
+ calendar_repository_epv.delete_object = cal_repo_delete_object;
+ calendar_repository_epv.update_object = cal_repo_update_object;
+ calendar_repository_epv.done = cal_repo_done;
+
+ calendar_repository_vepv.GNOME_Calendar_Repository_epv =
+ &calendar_repository_epv;
+
+ calendar_repository_servant.vepv = &calendar_repository_vepv;
+}
+
+/*
+ * Initializes the CORBA parts of the @calendar object
+ */
+void
+gnome_calendar_create_corba_server (GnomeCalendar *calendar)
+{
+ static gboolean class_inited = FALSE;
+ CalendarServant *calendar_servant;
+ CORBA_Environment ev;
+
+ if (!class_inited){
+ init_calendar_repo_class ();
+ class_inited = TRUE;
+ }
+
+ calendar_servant = g_new0 (CalendarServant, 1);
+ calendar_servant->servant.vepv = &calendar_repository_vepv;
+ calendar_servant->calendar = calendar;
+
+ CORBA_exception_init (&ev);
+ POA_GNOME_Calendar_Repository__init ((PortableServer_Servant) calendar_servant, &ev);
+ CORBA_free (
+ PortableServer_POA_activate_object (poa, calendar_servant, &ev));
+ calendar->cal->corba_server = PortableServer_POA_servant_to_reference (
+ poa, calendar_servant, &ev);
+ CORBA_exception_free (&ev);
+}
+