2009-09-14 23:51:28 +00:00
|
|
|
#ifndef _INCLUDE_CRYPTO_R_
|
|
|
|
#define _INCLUDE_CRYPTO_R_
|
|
|
|
|
|
|
|
#include <list.h>
|
|
|
|
#include <r_types.h>
|
|
|
|
|
|
|
|
enum {
|
|
|
|
R_CRYPTO_MODE_ECB,
|
|
|
|
R_CRYPTO_MODE_CBC,
|
|
|
|
R_CRYPTO_MODE_OFB,
|
|
|
|
R_CRYPTO_MODE_CFB,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
R_CRYPTO_DIR_CIPHER,
|
|
|
|
R_CRYPTO_DIR_DECIPHER,
|
|
|
|
};
|
|
|
|
|
2010-01-04 00:25:52 +00:00
|
|
|
typedef struct r_crypto_t {
|
2010-05-25 23:42:22 +00:00
|
|
|
struct r_crypto_plugin_t* h;
|
2009-09-14 23:51:28 +00:00
|
|
|
ut8 *key;
|
|
|
|
ut8 *iv;
|
|
|
|
int key_len;
|
|
|
|
ut8 *output;
|
|
|
|
int output_len;
|
|
|
|
int output_size;
|
|
|
|
void *user;
|
2010-05-26 16:25:35 +00:00
|
|
|
struct list_head plugins;
|
2010-01-26 00:28:33 +00:00
|
|
|
} RCrypto;
|
2009-09-14 23:51:28 +00:00
|
|
|
|
2010-05-25 23:42:22 +00:00
|
|
|
typedef struct r_crypto_plugin_t {
|
2009-09-14 23:51:28 +00:00
|
|
|
const char *name;
|
|
|
|
int (*get_key_size)(struct r_crypto_t* cry);
|
|
|
|
int (*set_iv)(struct r_crypto_t* cry, const ut8 *iv);
|
|
|
|
int (*set_key)(struct r_crypto_t* cry, const ut8 *key, int mode, int direction);
|
|
|
|
int (*update)(struct r_crypto_t* cry, const ut8 *buf, int len);
|
|
|
|
int (*final)(struct r_crypto_t* cry, const ut8 *buf, int len);
|
|
|
|
int (*use)(const char *algo);
|
2009-09-15 11:24:28 +00:00
|
|
|
int (*fini)(struct r_crypto_t *cry);
|
2009-09-14 23:51:28 +00:00
|
|
|
struct list_head list;
|
2010-05-25 23:42:22 +00:00
|
|
|
} RCryptoPlugin;
|
2009-09-14 23:51:28 +00:00
|
|
|
|
2009-12-24 02:17:53 +00:00
|
|
|
#ifdef R_API
|
2009-09-15 11:24:28 +00:00
|
|
|
R_API struct r_crypto_t *r_crypto_init(struct r_crypto_t *cry, int hard);
|
|
|
|
R_API struct r_crypto_t *r_crypto_as_new(struct r_crypto_t *cry);
|
2010-05-25 23:42:22 +00:00
|
|
|
R_API int r_crypto_add(struct r_crypto_t *cry, struct r_crypto_plugin_t *h);
|
2009-09-14 23:51:28 +00:00
|
|
|
R_API struct r_crypto_t *r_crypto_new();
|
|
|
|
R_API struct r_crypto_t *r_crypto_free(struct r_crypto_t *cry);
|
|
|
|
R_API int r_crypto_use(struct r_crypto_t *cry, const char *algo);
|
|
|
|
R_API int r_crypto_set_key(struct r_crypto_t *cry, const ut8* key, int mode, int direction);
|
|
|
|
R_API int r_crypto_get_key_size(struct r_crypto_t *cry);
|
|
|
|
R_API int r_crypto_set_iv(struct r_crypto_t *cry, const ut8 *iv);
|
|
|
|
R_API int r_crypto_update(struct r_crypto_t *cry, ut8 *buf, int len);
|
|
|
|
R_API int r_crypto_final(struct r_crypto_t *cry, ut8 *buf, int len);
|
|
|
|
R_API int r_crypto_append(struct r_crypto_t *cry, const ut8 *buf, int len);
|
|
|
|
R_API ut8 *r_crypto_get_output(struct r_crypto_t *cry);
|
2009-12-24 02:17:53 +00:00
|
|
|
#endif
|
2009-09-14 23:51:28 +00:00
|
|
|
|
|
|
|
/* plugin pointers */
|
2010-05-25 23:42:22 +00:00
|
|
|
extern struct r_crypto_plugin_t r_crypto_plugin_aes;
|
2009-12-24 02:17:53 +00:00
|
|
|
|
2009-09-14 23:51:28 +00:00
|
|
|
#endif
|