2015-04-02 08:56:18 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @ingroup sys_crypto
|
|
|
|
* @{
|
|
|
|
* @file ciphers.c
|
|
|
|
* @author Nico von Geyso <nico.geyso@fu-berlin.de>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "crypto/ciphers.h"
|
|
|
|
|
|
|
|
|
2019-10-08 15:07:28 +02:00
|
|
|
int cipher_init(cipher_t *cipher, cipher_id_t cipher_id, const uint8_t *key,
|
2015-04-02 08:56:18 +02:00
|
|
|
uint8_t key_size)
|
|
|
|
{
|
|
|
|
if (key_size > cipher_id->max_key_size) {
|
|
|
|
return CIPHER_ERR_INVALID_KEY_SIZE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cipher->interface = cipher_id;
|
|
|
|
return cipher->interface->init(&cipher->context, key, key_size);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-10-08 15:07:28 +02:00
|
|
|
int cipher_encrypt(const cipher_t *cipher, const uint8_t *input,
|
|
|
|
uint8_t *output)
|
2015-04-02 08:56:18 +02:00
|
|
|
{
|
|
|
|
return cipher->interface->encrypt(&cipher->context, input, output);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-10-08 15:07:28 +02:00
|
|
|
int cipher_decrypt(const cipher_t *cipher, const uint8_t *input,
|
|
|
|
uint8_t *output)
|
2015-04-02 08:56:18 +02:00
|
|
|
{
|
|
|
|
return cipher->interface->decrypt(&cipher->context, input, output);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-10-08 15:07:28 +02:00
|
|
|
int cipher_get_block_size(const cipher_t *cipher)
|
2015-04-02 08:56:18 +02:00
|
|
|
{
|
|
|
|
return cipher->interface->block_size;
|
|
|
|
}
|