summaryrefslogtreecommitdiffstats
path: root/examples
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2010-10-01 07:44:09 +0200
committerMarcel Holtmann <marcel@holtmann.org>2010-10-01 07:44:09 +0200
commit88f1b3c85e746f6e5c4e3828d59a92f4a548c0d4 (patch)
tree2828405d68691deced6bc5a63202aa67a07adc3b /examples
parentb7f6b1c997566df9cd279ee45c88c216112bc075 (diff)
downloadofono-88f1b3c85e746f6e5c4e3828d59a92f4a548c0d4.tar.bz2
build: Move example plugins to its own directory
Diffstat (limited to 'examples')
-rw-r--r--examples/history.c204
-rw-r--r--examples/nettime.c84
2 files changed, 288 insertions, 0 deletions
diff --git a/examples/history.c b/examples/history.c
new file mode 100644
index 00000000..b7aec061
--- /dev/null
+++ b/examples/history.c
@@ -0,0 +1,204 @@
+/*
+ *
+ * oFono - Open Source Telephony
+ *
+ * Copyright (C) 2008-2010 Intel Corporation. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <string.h>
+#include <glib.h>
+
+#define OFONO_API_SUBJECT_TO_CHANGE
+#include <ofono/plugin.h>
+#include <ofono/log.h>
+#include <ofono/history.h>
+#include <ofono/types.h>
+
+#include "common.h"
+
+static int example_history_probe(struct ofono_history_context *context)
+{
+ ofono_debug("Example History Probe for modem: %p", context->modem);
+ return 0;
+}
+
+static void example_history_remove(struct ofono_history_context *context)
+{
+ ofono_debug("Example History Remove for modem: %p", context->modem);
+}
+
+static void example_history_call_ended(struct ofono_history_context *context,
+ const struct ofono_call *call,
+ time_t start, time_t end)
+{
+ const char *from = "Unknown";
+ char buf[128];
+
+ ofono_debug("Call Ended on modem: %p", context->modem);
+
+ if (call->type != 0)
+ return;
+
+ ofono_debug("Voice Call, %s",
+ call->direction ? "Incoming" : "Outgoing");
+
+ if (call->clip_validity == 0)
+ from = phone_number_to_string(&call->phone_number);
+
+ if (call->direction == 0)
+ ofono_debug("To: %s", from);
+ else
+ ofono_debug("From: %s", from);
+
+ strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", localtime(&start));
+ buf[127] = '\0';
+ ofono_debug("StartTime: %s", buf);
+
+ strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", localtime(&end));
+ buf[127] = '\0';
+ ofono_debug("EndTime: %s", buf);
+}
+
+static void example_history_call_missed(struct ofono_history_context *context,
+ const struct ofono_call *call,
+ time_t when)
+{
+ const char *from = "Unknown";
+ char buf[128];
+
+ ofono_debug("Call Missed on modem: %p", context->modem);
+
+ if (call->type != 0)
+ return;
+
+ ofono_debug("Voice Call, %s",
+ call->direction ? "Incoming" : "Outgoing");
+
+ if (call->clip_validity == 0)
+ from = phone_number_to_string(&call->phone_number);
+
+ ofono_debug("From: %s", from);
+ strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", localtime(&when));
+ buf[127] = '\0';
+ ofono_debug("When: %s", buf);
+}
+
+static void example_history_sms_received(struct ofono_history_context *context,
+ const struct ofono_uuid *uuid,
+ const char *from,
+ const struct tm *remote,
+ const struct tm *local,
+ const char *text)
+{
+ char buf[128];
+
+ ofono_debug("Incoming SMS on modem: %p", context->modem);
+ ofono_debug("InternalMessageId: %s", ofono_uuid_to_str(uuid));
+ ofono_debug("From: %s", from);
+
+ strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", local);
+ buf[127] = '\0';
+ ofono_debug("Local Sent Time: %s", buf);
+
+ strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", remote);
+ buf[127] = '\0';
+ ofono_debug("Remote Sent Time: %s", buf);
+
+ ofono_debug("Text: %s", text);
+}
+
+static void example_history_sms_send_pending(struct ofono_history_context *context,
+ const struct ofono_uuid *uuid,
+ const char *to, time_t when,
+ const char *text)
+{
+ char buf[128];
+
+ ofono_debug("Sending SMS on modem: %p", context->modem);
+ ofono_debug("InternalMessageId: %s", ofono_uuid_to_str(uuid));
+ ofono_debug("To: %s:", to);
+
+ strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", localtime(&when));
+ buf[127] = '\0';
+ ofono_debug("Local Time: %s", buf);
+ ofono_debug("Text: %s", text);
+}
+
+static void example_history_sms_send_status(
+ struct ofono_history_context *context,
+ const struct ofono_uuid *uuid,
+ time_t when,
+ enum ofono_history_sms_status s)
+{
+ char buf[128];
+
+ strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", localtime(&when));
+ buf[127] = '\0';
+
+ switch (s) {
+ case OFONO_HISTORY_SMS_STATUS_PENDING:
+ break;
+ case OFONO_HISTORY_SMS_STATUS_SUBMITTED:
+ ofono_debug("SMS %s submitted successfully",
+ ofono_uuid_to_str(uuid));
+ ofono_debug("Submission Time: %s", buf);
+ break;
+ case OFONO_HISTORY_SMS_STATUS_SUBMIT_FAILED:
+ ofono_debug("Sending SMS %s failed", ofono_uuid_to_str(uuid));
+ ofono_debug("Failure Time: %s", buf);
+ break;
+ case OFONO_HISTORY_SMS_STATUS_DELIVERED:
+ ofono_debug("SMS delivered, msg_id: %s, time: %s",
+ ofono_uuid_to_str(uuid), buf);
+ break;
+ case OFONO_HISTORY_SMS_STATUS_DELIVER_FAILED:
+ ofono_debug("SMS undeliverable, msg_id: %s, time: %s",
+ ofono_uuid_to_str(uuid), buf);
+ break;
+ default:
+ break;
+ }
+}
+
+static struct ofono_history_driver example_driver = {
+ .name = "Example Call History",
+ .probe = example_history_probe,
+ .remove = example_history_remove,
+ .call_ended = example_history_call_ended,
+ .call_missed = example_history_call_missed,
+ .sms_received = example_history_sms_received,
+ .sms_send_pending = example_history_sms_send_pending,
+ .sms_send_status = example_history_sms_send_status,
+};
+
+static int example_history_init(void)
+{
+ return ofono_history_driver_register(&example_driver);
+}
+
+static void example_history_exit(void)
+{
+ ofono_history_driver_unregister(&example_driver);
+}
+
+OFONO_PLUGIN_DEFINE(example_history, "Example Call History Plugin",
+ VERSION, OFONO_PLUGIN_PRIORITY_DEFAULT,
+ example_history_init, example_history_exit)
diff --git a/examples/nettime.c b/examples/nettime.c
new file mode 100644
index 00000000..60045be5
--- /dev/null
+++ b/examples/nettime.c
@@ -0,0 +1,84 @@
+/*
+ *
+ * oFono - Open Source Telephony
+ *
+ * Copyright (C) 2008-2010 Nokia Corporation and/or its subsidiary(-ies).
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <string.h>
+#include <glib.h>
+
+#define OFONO_API_SUBJECT_TO_CHANGE
+#include <ofono/plugin.h>
+#include <ofono/log.h>
+#include <ofono/nettime.h>
+#include <ofono/types.h>
+
+#include "common.h"
+
+static int example_nettime_probe(struct ofono_nettime_context *context)
+{
+ ofono_debug("Example Network Time Probe for modem: %p",
+ context->modem);
+ return 0;
+}
+
+static void example_nettime_remove(struct ofono_nettime_context *context)
+{
+ ofono_debug("Example Network Time Remove for modem: %p",
+ context->modem);
+}
+
+static void example_nettime_info_received(struct ofono_nettime_context *context,
+ struct ofono_network_time *info)
+{
+ if (!info)
+ return;
+
+ ofono_debug("Received a network time notification on modem: %p",
+ context->modem);
+ ofono_debug("Time: %04d-%02d-%02d %02d:%02d:%02d%c%02d:%02d (DST=%d)",
+ info->year, info->mon, info->mday, info->hour,
+ info->min, info->sec, info->utcoff > 0 ? '+' : '-',
+ info->utcoff / 3600, (info->utcoff % 3600) / 60,
+ info->dst / 3600);
+}
+
+static struct ofono_nettime_driver example_driver = {
+ .name = "Example Network Time",
+ .probe = example_nettime_probe,
+ .remove = example_nettime_remove,
+ .info_received = example_nettime_info_received,
+};
+
+static int example_nettime_init(void)
+{
+ return ofono_nettime_driver_register(&example_driver);
+}
+
+static void example_nettime_exit(void)
+{
+ ofono_nettime_driver_unregister(&example_driver);
+}
+
+OFONO_PLUGIN_DEFINE(example_nettime, "Example Network Time Plugin",
+ VERSION, OFONO_PLUGIN_PRIORITY_DEFAULT,
+ example_nettime_init, example_nettime_exit)