[epiphany/wip/sync: 55/86] sync: Move _concatenate_bytes() from utils to crypto
- From: Gabriel Ivașcu <gabrielivascu src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [epiphany/wip/sync: 55/86] sync: Move _concatenate_bytes() from utils to crypto
- Date: Tue, 28 Mar 2017 20:58:32 +0000 (UTC)
commit 0385adb38145db50a5f5ec2317d0d173b4737bad
Author: Gabriel Ivascu <ivascu gabriel59 gmail com>
Date: Thu Mar 9 19:38:41 2017 +0200
sync: Move _concatenate_bytes() from utils to crypto
src/sync/ephy-sync-crypto.c | 50 +++++++++++++++++++++++++++++++++---------
src/sync/ephy-sync-utils.c | 28 ------------------------
src/sync/ephy-sync-utils.h | 3 --
3 files changed, 39 insertions(+), 42 deletions(-)
---
diff --git a/src/sync/ephy-sync-crypto.c b/src/sync/ephy-sync-crypto.c
index 9697ca7..ff26368 100644
--- a/src/sync/ephy-sync-crypto.c
+++ b/src/sync/ephy-sync-crypto.c
@@ -358,6 +358,34 @@ ephy_sync_crypto_append_to_header (char *header,
return new_header;
}
+static guint8 *
+ephy_sync_crypto_concat_bytes (const guint8 *bytes,
+ gsize bytes_len,
+ ...)
+{
+ va_list args;
+ guint8 *next;
+ guint8 *out;
+ gsize next_len;
+ gsize out_len;
+
+ out_len = bytes_len;
+ out = g_malloc (out_len);
+ memcpy (out, bytes, out_len);
+
+ va_start (args, bytes_len);
+ while ((next = va_arg (args, guint8 *)) != NULL) {
+ next_len = va_arg (args, gsize);
+ out = g_realloc (out, out_len + next_len);
+ memcpy (out + out_len, next, next_len);
+ out_len += next_len;
+ }
+
+ va_end (args);
+
+ return out;
+}
+
static void
ephy_sync_crypto_hkdf (const guint8 *in,
gsize in_len,
@@ -406,12 +434,12 @@ ephy_sync_crypto_hkdf (const guint8 *in,
for (gsize i = 0; i < n; i++, counter++) {
if (i == 0) {
- data = ephy_sync_utils_concatenate_bytes (info, info_len, &counter, 1, NULL);
+ data = ephy_sync_crypto_concat_bytes (info, info_len, &counter, 1, NULL);
data_len = info_len + 1;
} else {
- data = ephy_sync_utils_concatenate_bytes (out_full + (i - 1) * hash_len, hash_len,
- info, info_len, &counter, 1,
- NULL);
+ data = ephy_sync_crypto_concat_bytes (out_full + (i - 1) * hash_len, hash_len,
+ info, info_len, &counter, 1,
+ NULL);
data_len = hash_len + info_len + 1;
}
@@ -731,18 +759,18 @@ ephy_sync_crypto_derive_master_keys (const guint8 *kB,
salt, EPHY_SYNC_TOKEN_LENGTH,
kB, EPHY_SYNC_TOKEN_LENGTH);
prk = ephy_sync_crypto_decode_hex (prk_hex);
- tmp = ephy_sync_utils_concatenate_bytes ((guint8 *)info, strlen (info),
- "\x01", 1,
- NULL);
+ tmp = ephy_sync_crypto_concat_bytes ((guint8 *)info, strlen (info),
+ "\x01", 1,
+ NULL);
aes_key_hex = g_compute_hmac_for_data (G_CHECKSUM_SHA256,
prk, EPHY_SYNC_TOKEN_LENGTH,
tmp, strlen (info) + 1);
*aes_key = ephy_sync_crypto_decode_hex (aes_key_hex);
g_free (tmp);
- tmp = ephy_sync_utils_concatenate_bytes (*aes_key, EPHY_SYNC_TOKEN_LENGTH,
- (guint8 *)info, strlen (info),
- "\x02", 1,
- NULL);
+ tmp = ephy_sync_crypto_concat_bytes (*aes_key, EPHY_SYNC_TOKEN_LENGTH,
+ (guint8 *)info, strlen (info),
+ "\x02", 1,
+ NULL);
hmac_key_hex = g_compute_hmac_for_data (G_CHECKSUM_SHA256,
prk, EPHY_SYNC_TOKEN_LENGTH,
tmp, EPHY_SYNC_TOKEN_LENGTH + strlen (info) + 1);
diff --git a/src/sync/ephy-sync-utils.c b/src/sync/ephy-sync-utils.c
index b5efc8a..ca60d5f 100644
--- a/src/sync/ephy-sync-utils.c
+++ b/src/sync/ephy-sync-utils.c
@@ -156,34 +156,6 @@ ephy_sync_utils_find_and_replace (const char *src,
return out;
}
-guint8 *
-ephy_sync_utils_concatenate_bytes (const guint8 *bytes,
- gsize bytes_len,
- ...)
-{
- va_list args;
- guint8 *next;
- guint8 *out;
- gsize next_len;
- gsize out_len;
-
- out_len = bytes_len;
- out = g_malloc (out_len);
- memcpy (out, bytes, out_len);
-
- va_start (args, bytes_len);
- while ((next = va_arg (args, guint8 *)) != NULL) {
- next_len = va_arg (args, gsize);
- out = g_realloc (out, out_len + next_len);
- memcpy (out + out_len, next, next_len);
- out_len += next_len;
- }
-
- va_end (args);
-
- return out;
-}
-
gint64
ephy_sync_utils_current_time_seconds (void)
{
diff --git a/src/sync/ephy-sync-utils.h b/src/sync/ephy-sync-utils.h
index 883689d..4da216b 100644
--- a/src/sync/ephy-sync-utils.h
+++ b/src/sync/ephy-sync-utils.h
@@ -43,9 +43,6 @@ EphySyncTokenType ephy_sync_utils_token_type_from_name (const char *na
char *ephy_sync_utils_find_and_replace (const char *src,
const char *find,
const char *repl);
-guint8 *ephy_sync_utils_concatenate_bytes (const guint8 *bytes,
- gsize bytes_len,
- ...) G_GNUC_NULL_TERMINATED;
gint64 ephy_sync_utils_current_time_seconds (void);
G_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]