:: [maemo-leste] SMSes in mbox was Re:…
Inizio della pagina
Delete this message
Reply to this message
Autore: Pavel Machek
Data:  
To: Tony Lindgren
CC: Merlijn Wajer, sre, nekit1000, mpartap, martin_rysavy, maemo-leste, Ivaylo Dimitrov, Arthur D.
Vecchi argomenti: Re: [maemo-leste] Grand plan to get make phones... phone (for Motorola Droid 4)
Oggetto: [maemo-leste] SMSes in mbox was Re: Grand plan to get make phones... phone (for Motorola Droid 4)
Hi!

On Sun 2020-05-10 08:32:01, Tony Lindgren wrote:
> * Pavel Machek <pavel@???> [200510 15:15]:
> > Now, I see you want to be similar to Maemo (and it makes some sense)
> > but I'd really like to see different design, one that treats SMSes as
> > emails (not like instant messages), so I could read them using mutt and
> > use imap protocol to access them remotely. I'd like to store my
> > contacts in plain text (version controlled in git), not in binary
> > databases.
>
> Yeah me too. I've been meaning to do python scripts or c programs
> to provide droid4-sms-tools type functionality via ofono but have
> not had the chance.
>
> For smtp to ofono program or script the start-up time should be
> minimal, so probably c makes sense there. The current droid4-sms-tools
> ruby start up time is few seconds to send an sms.. I think python
> will also take 0.7 seconds.
>
> For readings incoming sms from onono and writing it to a Maildir or
> mbox, memory consumption should be minimal as that program will
> be constanly running.. So again c makes sense there for many MBs of
> memory savings.
>
> Also, for standalone devices the dependencies with ofono should be
> minimal, so again c would make sense for this. So for example the
> huge size of rust related binaries would add an extra dependency
> for embedded systems.


Rust is actually not as bad as you think. Definitely better than
Python / Ruby.

But it has different problem: if you have separate component that
talks to ofono, and it dies for some reason (OOM kill?), your sms will
keep coming, and will be discarded.

So I believe it makes sense to do it ofono directly (thus in C): if
ofono dies for some reason, SMS will still come, but there will be
noone to acknowledge it, so it will be delivered again after reboot.

I even started coding it...

Best regards,
                                Pavel


diff --git a/Makefile.am b/Makefile.am
index 6aa8f8fe..e4072dec 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -658,6 +658,9 @@ builtin_sources += plugins/file-provision.c

endif

+builtin_modules += mail_history
+builtin_sources += plugins/mail-history.c
+
 if MAINTAINER_MODE
 builtin_modules += example_history
 builtin_sources += examples/history.c
diff --git a/plugins/mail-history.c b/plugins/mail-history.c
new file mode 100644
index 00000000..034f054e
--- /dev/null
+++ b/plugins/mail-history.c
@@ -0,0 +1,248 @@
+/*
+ *
+ *  oFono - Open Source Telephony
+ *
+ *  Copyright (C) 2008-2011  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 <stdio.h>
+
+#include "common.h"
+
+static int mail_history_probe(struct ofono_history_context *context)
+{
+    ofono_debug("Example History Probe for modem: %p", context->modem);
+    return 0;
+}
+
+static void mail_history_remove(struct ofono_history_context *context)
+{
+    ofono_debug("Example History Remove for modem: %p", context->modem);
+}
+
+static FILE *mail_history_open(struct ofono_history_context *context)
+{
+    const char *mbox = "/tmp/sms.mbox";
+    FILE *fp = fopen(mbox, "a");
+    return fp;
+}
+
+static int mail_history_close(struct ofono_history_context *context, FILE *fp)
+{
+    fclose(fp);
+    return 0;
+}
+
+static FILE *mail_history_header(struct ofono_history_context *context)
+{
+    FILE *fp = mail_history_open(context);
+    
+    fprintf(fp, "From ofono-event\n");
+    return 0;
+}
+
+static void mail_history_call_ended(struct ofono_history_context *context,
+                    const struct ofono_call *call,
+n                    time_t start, time_t end)
+{
+    const char *from = "Unknown";
+    const char *name = "";
+    char buf[128];
+    FILE *fp;
+
+    ofono_debug("Call Ended on modem: %p", context->modem);
+
+    if (call->type != 0)
+        return;
+
+    fp = mail_history_header(context);
+
+    ofono_debug("Voice Call, %s",
+            call->direction ? "Incoming" : "Outgoing");
+
+    if (call->clip_validity == 0)
+        from = phone_number_to_string(&call->phone_number);
+
+    if (call->cnap_validity == 0)
+        name = call->name;
+
+    if (call->direction == 0) {
+        fprintf(fp, "To: %s <%s@pstn>\n", name, from);
+        fprintf(fp, "Type: outgoing call ended\n");
+
+    } else {
+        fprintf(fp, "From: %s <%s@pstn>\n", name, from);
+        fprintf(fp, "Type: outgoing call ended\n");
+    }
+
+
+    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 mail_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);
+
+    if (call->cnap_validity == 0)
+        ofono_debug("Name from Network: %s\n", call->name);
+
+    strftime(buf, 127, "%Y-%m-%dT%H:%M:%S%z", localtime(&when));
+    buf[127] = '\0';
+    ofono_debug("When: %s", buf);
+}
+
+static void mail_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 mail_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 mail_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_SUBMIT_CANCELLED:
+        ofono_debug("Submission of SMS %s was canceled",
+                    ofono_uuid_to_str(uuid));
+        ofono_debug("Cancel 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 mail_driver = {
+    .name = "Example Call History",
+    .probe = mail_history_probe,
+    .remove = mail_history_remove,
+    .call_ended = mail_history_call_ended,
+    .call_missed = mail_history_call_missed,
+    .sms_received = mail_history_sms_received,
+    .sms_send_pending = mail_history_sms_send_pending,
+    .sms_send_status = mail_history_sms_send_status,
+};
+
+static int mail_history_init(void)
+{
+    return ofono_history_driver_register(&mail_driver);
+}
+
+static void mail_history_exit(void)
+{
+    ofono_history_driver_unregister(&mail_driver);
+}
+
+OFONO_PLUGIN_DEFINE(mail_history, "Example Call History Plugin",
+            VERSION, OFONO_PLUGIN_PRIORITY_DEFAULT,
+            mail_history_init, mail_history_exit)



--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html