2019-03-06 23:41:59 +02:00
|
|
|
/* ************************************************************************** */
|
|
|
|
/* */
|
|
|
|
/* ::: :::::::: */
|
|
|
|
/* ft_des.h :+: :+: :+: */
|
|
|
|
/* +:+ +:+ +:+ */
|
|
|
|
/* By: gtertysh <marvin@42.fr> +#+ +:+ +#+ */
|
|
|
|
/* +#+#+#+#+#+ +#+ */
|
|
|
|
/* Created: 2019/01/19 17:58:39 by gtertysh #+# #+# */
|
|
|
|
/* Updated: 2019/01/19 17:59:19 by gtertysh ### ########.fr */
|
|
|
|
/* */
|
|
|
|
/* ************************************************************************** */
|
|
|
|
|
|
|
|
#ifndef FT_DES_H
|
|
|
|
# define FT_DES_H
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
# include <stdint.h>
|
|
|
|
|
|
|
|
# define FT_DES_BYTE_BLOCK_SIZE 8
|
2019-03-06 23:41:59 +02:00
|
|
|
# define FT_DES_BIT_BLOCK_SIZE 64
|
2019-03-10 18:39:26 +02:00
|
|
|
# define FT_DES_EXPANDED_HALF_BLOCK_SIZE 48
|
2019-03-11 00:22:54 +02:00
|
|
|
# define FT_DES_S_BOX_INPUT_SIZE 6
|
|
|
|
# define FT_DES_S_BOX_OUTPUT_SIZE 4
|
|
|
|
# define FT_DES_S_BOX_TABLE_ROWS 4
|
|
|
|
# define FT_DES_S_BOX_TABLE_COLUMNS 16
|
2019-03-15 00:00:15 +02:00
|
|
|
# define FT_DES_ROUND_KEY_SIZE 48
|
2019-03-12 00:06:46 +02:00
|
|
|
# define FT_DES_INITIAL_KEY_SIZE 64
|
|
|
|
# define FT_DES_REDUCED_KEY_SIZE 56
|
2019-03-13 00:43:47 +02:00
|
|
|
# define FT_DES_ROUND_COUNT 16
|
2019-03-15 00:00:15 +02:00
|
|
|
# define FT_DES_READ_SIZE 1024
|
2019-03-17 18:21:22 +02:00
|
|
|
# define FT_DES_MAX_HEX_KEY 16
|
2019-03-15 00:00:15 +02:00
|
|
|
|
|
|
|
typedef uint64_t t_byte8;
|
|
|
|
typedef unsigned char t_byte1;
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct s_des_ctx
|
|
|
|
{
|
|
|
|
int input_fd;
|
|
|
|
int output_fd;
|
|
|
|
int decode;
|
2019-03-22 01:16:48 +02:00
|
|
|
int b64;
|
2019-03-15 00:00:15 +02:00
|
|
|
int output_in_base64;
|
|
|
|
int readed;
|
|
|
|
t_byte1 buffer[FT_DES_BYTE_BLOCK_SIZE];
|
|
|
|
t_byte1 key[FT_DES_INITIAL_KEY_SIZE];
|
|
|
|
t_byte1 round_keys[FT_DES_ROUND_COUNT]
|
|
|
|
[FT_DES_ROUND_KEY_SIZE];
|
|
|
|
} t_des_ctx;
|
|
|
|
|
|
|
|
typedef int (*t_ft_des_arg_parser_function)
|
|
|
|
(int argc, char **argv, int position, t_des_ctx *c);
|
2019-03-06 23:41:59 +02:00
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
typedef struct s_des_argument_parser
|
|
|
|
{
|
|
|
|
const char *arg;
|
|
|
|
t_ft_des_arg_parser_function arg_parser;
|
|
|
|
} t_des_argument_parser;
|
2019-03-06 23:41:59 +02:00
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
typedef struct s_des_chunk_buffer
|
2019-03-14 12:45:15 +02:00
|
|
|
{
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 buffer[FT_DES_BYTE_BLOCK_SIZE];
|
|
|
|
t_byte8 readed;
|
|
|
|
} t_des_chunk_buffer;
|
2019-03-14 12:45:15 +02:00
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_initial_permutation
|
2019-03-06 23:41:59 +02:00
|
|
|
(
|
|
|
|
t_byte1 message[FT_DES_BIT_BLOCK_SIZE],
|
|
|
|
t_byte1 initial_permutation[FT_DES_BIT_BLOCK_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_final_permutation
|
2019-03-10 18:39:26 +02:00
|
|
|
(
|
|
|
|
t_byte1 before[FT_DES_BIT_BLOCK_SIZE],
|
|
|
|
t_byte1 final_permutation[FT_DES_BIT_BLOCK_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_expansion_box
|
2019-03-10 18:39:26 +02:00
|
|
|
(
|
|
|
|
t_byte1 half[FT_DES_BIT_BLOCK_SIZE / 2],
|
|
|
|
t_byte1 expanded[FT_DES_EXPANDED_HALF_BLOCK_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE],
|
|
|
|
t_byte1 table[FT_DES_S_BOX_TABLE_ROWS][FT_DES_S_BOX_TABLE_COLUMNS]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_1
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_2
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_3
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_4
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_5
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_6
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_7
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_s_box_8
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_S_BOX_INPUT_SIZE],
|
|
|
|
t_byte1 output[FT_DES_S_BOX_OUTPUT_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_feistel_function_permutation
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 input[FT_DES_BIT_BLOCK_SIZE / 2],
|
|
|
|
t_byte1 output[FT_DES_BIT_BLOCK_SIZE / 2]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_feistel_function
|
2019-03-11 00:22:54 +02:00
|
|
|
(
|
|
|
|
t_byte1 right_half[FT_DES_BIT_BLOCK_SIZE / 2],
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 key[FT_DES_ROUND_KEY_SIZE],
|
2019-03-11 00:22:54 +02:00
|
|
|
t_byte1 output[FT_DES_BIT_BLOCK_SIZE / 2]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_key_permuted_choice_one
|
2019-03-12 00:06:46 +02:00
|
|
|
(
|
|
|
|
t_byte1 initial_key[FT_DES_INITIAL_KEY_SIZE],
|
|
|
|
t_byte1 reduced_key[FT_DES_REDUCED_KEY_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_key_permuted_choice_two
|
2019-03-12 00:06:46 +02:00
|
|
|
(
|
|
|
|
t_byte1 input_key[FT_DES_REDUCED_KEY_SIZE],
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 round_key[FT_DES_ROUND_KEY_SIZE]
|
2019-03-12 00:06:46 +02:00
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_derive_encryption_round_key
|
2019-03-12 00:06:46 +02:00
|
|
|
(
|
|
|
|
t_byte1 input_key[FT_DES_REDUCED_KEY_SIZE],
|
|
|
|
t_byte1 round,
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 round_key[FT_DES_ROUND_KEY_SIZE]
|
2019-03-12 00:06:46 +02:00
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_derive_decryption_round_key
|
2019-03-13 19:40:38 +02:00
|
|
|
(
|
|
|
|
t_byte1 input_key[FT_DES_REDUCED_KEY_SIZE],
|
|
|
|
t_byte1 round,
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 round_key[FT_DES_ROUND_KEY_SIZE]
|
2019-03-13 19:40:38 +02:00
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_generate_encryption_round_keys
|
2019-03-13 19:40:38 +02:00
|
|
|
(
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 input_key[FT_DES_INITIAL_KEY_SIZE],
|
|
|
|
t_byte1 keys[FT_DES_ROUND_COUNT][FT_DES_ROUND_KEY_SIZE]
|
2019-03-13 19:40:38 +02:00
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_generate_decryption_round_keys
|
2019-03-13 18:28:15 +02:00
|
|
|
(
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 input_key[FT_DES_INITIAL_KEY_SIZE],
|
|
|
|
t_byte1 keys[FT_DES_ROUND_COUNT][FT_DES_ROUND_KEY_SIZE]
|
2019-03-13 18:28:15 +02:00
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_rotate_half_key_left
|
2019-03-12 00:06:46 +02:00
|
|
|
(
|
|
|
|
t_byte1 half[FT_DES_REDUCED_KEY_SIZE / 2],
|
|
|
|
t_byte1 rotation_number
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_rotate_half_key_right
|
2019-03-12 00:06:46 +02:00
|
|
|
(
|
|
|
|
t_byte1 half[FT_DES_REDUCED_KEY_SIZE / 2],
|
|
|
|
t_byte1 rotation_number
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_round
|
2019-03-13 00:43:47 +02:00
|
|
|
(
|
|
|
|
t_byte1 left_half[FT_DES_BIT_BLOCK_SIZE / 2],
|
|
|
|
t_byte1 right_half[FT_DES_BIT_BLOCK_SIZE / 2],
|
2019-03-15 00:00:15 +02:00
|
|
|
t_byte1 key[FT_DES_ROUND_KEY_SIZE]
|
|
|
|
);
|
|
|
|
|
|
|
|
void ft_des_process_block
|
|
|
|
(
|
|
|
|
t_byte1 plaintext[FT_DES_BYTE_BLOCK_SIZE],
|
|
|
|
t_byte1 keys[FT_DES_ROUND_COUNT][FT_DES_ROUND_KEY_SIZE],
|
|
|
|
t_byte1 ciphertext[FT_DES_BYTE_BLOCK_SIZE]
|
2019-03-13 00:43:47 +02:00
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_print_error
|
2019-03-13 00:43:47 +02:00
|
|
|
(
|
2019-03-15 00:00:15 +02:00
|
|
|
const char *error
|
2019-03-13 00:43:47 +02:00
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_ecb
|
2019-03-14 12:45:15 +02:00
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv
|
|
|
|
);
|
|
|
|
|
2019-03-15 00:00:15 +02:00
|
|
|
void ft_des_init_ctx
|
|
|
|
(
|
|
|
|
t_des_ctx *ctx
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_key_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_decode_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_encode_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_base64_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_input_file_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_output_file_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_password_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_init_vector_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
|
|
|
int ft_des_salt_arg_parser
|
|
|
|
(
|
|
|
|
int argc,
|
|
|
|
char **argv,
|
|
|
|
int position,
|
|
|
|
t_des_ctx *c
|
|
|
|
);
|
|
|
|
|
2019-03-22 01:16:48 +02:00
|
|
|
void ft_des_ecb_decrypt
|
2019-03-15 00:00:15 +02:00
|
|
|
(
|
|
|
|
t_des_ctx *ctx
|
|
|
|
);
|
|
|
|
|
2019-03-23 11:33:28 +02:00
|
|
|
void ft_des_ecb_decrypt_b64
|
|
|
|
(
|
|
|
|
t_des_ctx *ctx
|
|
|
|
);
|
|
|
|
|
2019-03-22 01:16:48 +02:00
|
|
|
void ft_des_ecb_encrypt
|
|
|
|
(
|
|
|
|
t_des_ctx *ctx
|
|
|
|
);
|
|
|
|
|
2019-03-23 11:33:28 +02:00
|
|
|
void ft_des_ecb_encrypt_b64
|
|
|
|
(
|
|
|
|
t_des_ctx *ctx
|
|
|
|
);
|
|
|
|
|
2019-03-22 01:16:48 +02:00
|
|
|
void ft_des_ecb_encode_process_chunk
|
2019-03-15 00:00:15 +02:00
|
|
|
(
|
|
|
|
t_des_ctx *ctx,
|
|
|
|
t_byte8 reaed,
|
|
|
|
t_byte1 buffer[FT_DES_READ_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-22 01:16:48 +02:00
|
|
|
void ft_des_ecb_finish_encrypt
|
2019-03-15 00:00:15 +02:00
|
|
|
(
|
|
|
|
t_des_ctx *ctx
|
|
|
|
);
|
|
|
|
|
|
|
|
void ft_des_generete_key_from_hex
|
|
|
|
(
|
|
|
|
char *hex_key,
|
|
|
|
t_byte1 initla_key[FT_DES_INITIAL_KEY_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-17 18:21:22 +02:00
|
|
|
const char *ft_des_hex_to_bit_key
|
|
|
|
(
|
|
|
|
const char *hex_key,
|
|
|
|
t_byte1 bits_key[FT_DES_INITIAL_KEY_SIZE]
|
|
|
|
);
|
|
|
|
|
2019-03-06 23:41:59 +02:00
|
|
|
#endif
|