/*
* Slitheen - a decoy routing system for censorship resistance
* Copyright (C) 2017 Cecylia Bocovich (cbocovic@uwaterloo.ca)
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 3.
*
* 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, see .
*
* Additional permission under GNU GPL version 3 section 7
*
* If you modify this Program, or any covered work, by linking or combining
* it with the OpenSSL library (or a modified version of that library),
* containing parts covered by the terms of [name of library's license],
* the licensors of this Program grant you additional permission to convey
* the resulting work. {Corresponding Source for a non-source form of such
* a combination shall include the source code for the parts of the OpenSSL
* library used as well as that of the covered work.}
*/
#ifndef _CRYPTO_H_
#define _CRYPTO_H_
#include
#include
# define n2s(c,s) ((s=(((unsigned int)(c[0]))<< 8)| \
(((unsigned int)(c[1])) )),c+=2)
int PRF(uint8_t *secret, int32_t secret_len,
uint8_t *seed1, int32_t seed1_len,
uint8_t *seed2, int32_t seed2_len,
uint8_t *seed3, int32_t seed3_len,
uint8_t *seed4, int32_t seed4_len,
uint8_t *output, int32_t output_len);
int peek_header(uint8_t *data);
int super_decrypt(uint8_t *data);
int generate_super_keys(uint8_t *secret);
typedef struct super_data_st {
uint8_t *header_key;
uint8_t *body_key;
EVP_MD_CTX *body_mac_ctx;
} super_data;
#define PRE_MASTER_LEN 256
#endif /* _CRYPTO_H_ */