First proof-of-concept implementation
This commit is contained in:
parent
638dbbf2d4
commit
46523cace4
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user