First proof-of-concept implementation

This commit is contained in:
Pierre Pronchery 2010-06-03 01:22:27 +00:00
parent 638dbbf2d4
commit 46523cace4

View File

@ -16,13 +16,27 @@
#include <stdarg.h> #include <stdarg.h>
#include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#include <string.h>
#include <errno.h>
#include <System.h>
#include "Phone.h" #include "Phone.h"
/* SMSCrypt */ /* SMSCrypt */
/* private */ /* private */
/* types */
typedef struct _SMSCrypt
{
char * secret;
size_t secret_len;
} SMSCrypt;
/* prototypes */
static int _smscrypt_init(PhonePlugin * plugin); static int _smscrypt_init(PhonePlugin * plugin);
static int _smscrypt_destroy(PhonePlugin * plugin);
static int _smscrypt_event(PhonePlugin * plugin, PhoneEvent event, ...); static int _smscrypt_event(PhonePlugin * plugin, PhoneEvent event, ...);
static void _smscrypt_settings(PhonePlugin * plugin); static void _smscrypt_settings(PhonePlugin * plugin);
@ -35,7 +49,7 @@ PhonePlugin plugin =
"SMS encryption", "SMS encryption",
NULL, NULL,
_smscrypt_init, _smscrypt_init,
NULL, _smscrypt_destroy,
_smscrypt_event, _smscrypt_event,
_smscrypt_settings, _smscrypt_settings,
NULL NULL
@ -47,23 +61,51 @@ PhonePlugin plugin =
/* smscrypt_init */ /* smscrypt_init */
static int _smscrypt_init(PhonePlugin * plugin) static int _smscrypt_init(PhonePlugin * plugin)
{ {
SMSCrypt * smscrypt;
char const * secret;
if((secret = plugin->helper->config_get(plugin->helper->phone,
"smscrypt", "secret")) == NULL)
return 1;
#ifdef DEBUG #ifdef DEBUG
fprintf(stderr, "DEBUG: %s() secret=\"%s\"\n", __func__, fprintf(stderr, "DEBUG: %s() secret=\"%s\"\n", __func__, secret);
plugin->helper->config_get(plugin->helper->phone,
"smscrypt", "secret"));
#endif #endif
if((smscrypt = malloc(sizeof(*smscrypt))) == NULL)
return error_set_code(1, "%s", strerror(errno));
plugin->priv = smscrypt;
smscrypt->secret = strdup(secret);
smscrypt->secret_len = strlen(secret);
if(smscrypt->secret == NULL || smscrypt->secret_len == 0)
{
_smscrypt_destroy(plugin);
return error_set_code(1, "%s", strerror(errno));
}
return 0;
}
/* smscrypt_destroy */
static int _smscrypt_destroy(PhonePlugin * plugin)
{
SMSCrypt * smscrypt = plugin->priv;
if(smscrypt->secret != NULL)
memset(smscrypt->secret, 0, smscrypt->secret_len);
free(smscrypt->secret);
free(smscrypt);
return 0; return 0;
} }
/* smscrypt_event */ /* smscrypt_event */
static void _smscrypt_event_sms_received(PhoneEncoding * encoding, char ** buf, static void _smscrypt_event_sms_receiving(SMSCrypt * smscrypt,
size_t * len); PhoneEncoding * encoding, char ** buf, size_t * len);
static void _smscrypt_event_sms_sending(PhoneEncoding * encoding, char ** buf, static void _smscrypt_event_sms_sending(SMSCrypt * smscrypt,
size_t * len); PhoneEncoding * encoding, char ** buf, size_t * len);
static int _smscrypt_event(PhonePlugin * plugin, PhoneEvent event, ...) static int _smscrypt_event(PhonePlugin * plugin, PhoneEvent event, ...)
{ {
SMSCrypt * smscrypt = plugin->priv;
va_list ap; va_list ap;
PhoneEncoding * encoding; PhoneEncoding * encoding;
char ** buf; char ** buf;
@ -77,13 +119,15 @@ static int _smscrypt_event(PhonePlugin * plugin, PhoneEvent event, ...)
encoding = va_arg(ap, PhoneEncoding *); encoding = va_arg(ap, PhoneEncoding *);
buf = va_arg(ap, char **); buf = va_arg(ap, char **);
len = va_arg(ap, size_t *); len = va_arg(ap, size_t *);
_smscrypt_event_sms_received(encoding, buf, len); _smscrypt_event_sms_receiving(smscrypt, encoding, buf,
len);
break; break;
case PHONE_EVENT_SMS_SENDING: case PHONE_EVENT_SMS_SENDING:
encoding = va_arg(ap, PhoneEncoding *); encoding = va_arg(ap, PhoneEncoding *);
buf = va_arg(ap, char **); buf = va_arg(ap, char **);
len = va_arg(ap, size_t *); len = va_arg(ap, size_t *);
_smscrypt_event_sms_sending(encoding, buf, len); _smscrypt_event_sms_sending(smscrypt, encoding, buf,
len);
break; break;
/* ignore the rest */ /* ignore the rest */
default: default:
@ -93,28 +137,42 @@ static int _smscrypt_event(PhonePlugin * plugin, PhoneEvent event, ...)
return 0; return 0;
} }
static void _smscrypt_event_sms_received(PhoneEncoding * encoding, char ** buf, static void _smscrypt_event_sms_receiving(SMSCrypt * smscrypt,
size_t * len) PhoneEncoding * encoding, char ** buf, size_t * len)
{ {
size_t i;
size_t j = 0;
#ifdef DEBUG #ifdef DEBUG
fprintf(stderr, "DEBUG: %s(%u, buf, %lu)\n", __func__, *encoding, fprintf(stderr, "DEBUG: %s(%u, buf, %lu)\n", __func__, *encoding,
*len); *len);
#endif #endif
if(*encoding == PHONE_ENCODING_UTF8) if(*encoding != PHONE_ENCODING_DATA)
return; /* not for us */ return; /* not for us */
/* FIXME really implement */ for(i = 0; i < *len; i++)
{
(*buf)[i] ^= smscrypt->secret[j++];
j %= smscrypt->secret_len;
}
*encoding = PHONE_ENCODING_UTF8; *encoding = PHONE_ENCODING_UTF8;
} }
static void _smscrypt_event_sms_sending(PhoneEncoding * encoding, char ** buf, static void _smscrypt_event_sms_sending(SMSCrypt * smscrypt,
size_t * len) PhoneEncoding * encoding, char ** buf, size_t * len)
{ {
size_t i;
size_t j = 0;
#ifdef DEBUG #ifdef DEBUG
fprintf(stderr, "DEBUG: %s(%u, buf, %lu)\n", __func__, *encoding, *len); fprintf(stderr, "DEBUG: %s(%u, buf, %lu)\n", __func__, *encoding, *len);
#endif #endif
if(*encoding != PHONE_ENCODING_UTF8) if(*encoding != PHONE_ENCODING_UTF8)
return; /* not for us */ return; /* not for us */
/* FIXME really implement */ for(i = 0; i < *len; i++)
{
(*buf)[i] ^= smscrypt->secret[j++];
j %= smscrypt->secret_len;
}
*encoding = PHONE_ENCODING_DATA; *encoding = PHONE_ENCODING_DATA;
} }