diff options
Diffstat (limited to 'src/analysis')
-rwxr-xr-x | src/analysis/Makefile.am | 1 | ||||
-rwxr-xr-x | src/analysis/db/Makefile.am | 14 | ||||
-rw-r--r-- | src/analysis/db/keymgn.c | 166 | ||||
-rw-r--r-- | src/analysis/db/keymgn.h | 37 |
4 files changed, 216 insertions, 2 deletions
diff --git a/src/analysis/Makefile.am b/src/analysis/Makefile.am index 0b65bbe..c143e1b 100755 --- a/src/analysis/Makefile.am +++ b/src/analysis/Makefile.am @@ -18,6 +18,7 @@ libanalysis_la_LIBADD = \ blocks/libanalysisblocks.la \ contents/libanalysiscontents.la \ db/libanalysisdb.la \ + db/libanalysiskeys.la \ decomp/libanalysisdecomp.la \ disass/libanalysisdisass.la \ types/libanalysistypes.la diff --git a/src/analysis/db/Makefile.am b/src/analysis/db/Makefile.am index 797025c..7e9f177 100755 --- a/src/analysis/db/Makefile.am +++ b/src/analysis/db/Makefile.am @@ -1,5 +1,6 @@ -noinst_LTLIBRARIES = libanalysisdb.la +noinst_LTLIBRARIES = libanalysisdb.la libanalysiskeys.la + libanalysisdb_la_SOURCES = \ cdb.h cdb.c \ @@ -15,10 +16,19 @@ libanalysisdb_la_LIBADD = \ items/libanalysisdbitems.la \ misc/libanalysisdbmisc.la - libanalysisdb_la_LDFLAGS = +libanalysiskeys_la_SOURCES = \ + keymgn.h keymgn.c + +libanalysiskeys_la_LIBADD = + +libanalysiskeys_la_CFLAGS = $(LIBSSL_CFLAGS) + +libanalysiskeys_la_LDFLAGS = $(LIBSSL_LIBS) + + AM_CPPFLAGS = $(LIBGTK_CFLAGS) $(LIBXML_CFLAGS) $(LIBARCHIVE_CFLAGS) $(LIBSQLITE_CFLAGS) AM_CFLAGS = $(DEBUG_CFLAGS) $(WARNING_FLAGS) $(COMPLIANCE_FLAGS) diff --git a/src/analysis/db/keymgn.c b/src/analysis/db/keymgn.c new file mode 100644 index 0000000..bcd8d28 --- /dev/null +++ b/src/analysis/db/keymgn.c @@ -0,0 +1,166 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * keymgn.c - mise en place et gestion des clefs cryptographiques + * + * Copyright (C) 2016 Cyrille Bagard + * + * This file is part of Chrysalide. + * + * OpenIDA 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; either version 3 of the License, or + * (at your option) any later version. + * + * OpenIDA 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 Foobar. If not, see <http://www.gnu.org/licenses/>. + */ + + +#include "keymgn.h" + + +#include <glib.h> +#include <malloc.h> +#include <stdio.h> +#include <unistd.h> +#include <openssl/evp.h> +#include <openssl/rsa.h> + + +#include <i18n.h> + + +#include "../../common/xdg.h" + + + +/* Met en place de nouvelles clefs RSA. */ +static bool generate_user_rsa_keys(const char *, const char *); + + + +/****************************************************************************** +* * +* Paramètres : - * +* * +* Description : S'assure que l'utilisateur dispose de clefs RSA. * +* * +* Retour : Bilan de l'opération. * +* * +* Remarques : - * +* * +******************************************************************************/ + +bool ensure_user_has_rsa_keys(void) +{ + bool result; /* Bilan à retourner */ + char *priv; /* Chemin de la clef privée */ + char *pub; /* Chemin de la clef publique */ + int priv_check; /* Bilan d'une vérification #1 */ + int pub_check; /* Bilan d'une vérification #2 */ + + result = NULL; + + priv = get_xdg_config_dir("chrysalide" G_DIR_SEPARATOR_S "id_rsa.priv"); + pub = get_xdg_config_dir("chrysalide" G_DIR_SEPARATOR_S "id_rsa.pub"); + + priv_check = access(priv, R_OK); + pub_check = access(pub, R_OK); + + result = (priv_check == 0 && pub_check == 0); + + if (!result) + { + result = generate_user_rsa_keys(priv, pub); + + if (!result) + fprintf(stderr, _("Unable to create new user RSA key pair.")); + + } + + free(priv); + free(pub); + + return result; + +} + + +/****************************************************************************** +* * +* Paramètres : priv = chemin d'accès pour la clef privée. * +* pub = chemin d'accès pour la clef publique. * +* * +* Description : Met en place de nouvelles clefs RSA. * +* * +* Retour : Bilan de l'opération. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static bool generate_user_rsa_keys(const char *priv, const char *pub) +{ + bool result; /* Bilan à retourner */ + EVP_PKEY_CTX *ctx; /* Contexte de génération */ + int ret; /* Bilan d'un appel */ + EVP_PKEY *pair; /* Paire de clefs RSA générée */ + char *filename; /* Chemin d'accès */ + FILE *stream; /* Flux ouvert en écriture */ + + result = false; + + /** + * Cf. https://www.openssl.org/docs/manmaster/crypto/EVP_PKEY_keygen.html + */ + + ctx = EVP_PKEY_CTX_new_id(EVP_PKEY_RSA, NULL); + if (ctx == NULL) goto euhrk_exit; + + ret = EVP_PKEY_keygen_init(ctx); + if (ret != 1) goto euhrk_exit; + + ret = EVP_PKEY_CTX_set_rsa_keygen_bits(ctx, 2048); + if (ret != 1) goto euhrk_exit; + + ret = EVP_PKEY_keygen(ctx, &pair); + if (ret != 1) goto euhrk_exit; + + /* Clef privée */ + + stream = fopen(priv, "wt"); + if (stream == NULL) goto euhrk_bad_write; + + ret = PEM_write_PrivateKey(stream, pair, NULL, NULL, 0, NULL, NULL); + if (ret != 1) goto euhrk_bad_write; + + fclose(stream); + + /* Clef publique */ + + stream = fopen(pub, "wt"); + if (stream == NULL) goto euhrk_bad_write; + + ret = PEM_write_PUBKEY(stream, pair); + if (ret != 1) goto euhrk_bad_write; + + result = true; + + euhrk_bad_write: + + fclose(stream); + + EVP_PKEY_free(pair); + + euhrk_exit: + + EVP_PKEY_CTX_free(ctx); + + return result; + +} diff --git a/src/analysis/db/keymgn.h b/src/analysis/db/keymgn.h new file mode 100644 index 0000000..4aa33db --- /dev/null +++ b/src/analysis/db/keymgn.h @@ -0,0 +1,37 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * keymgn.h - prototypes pour la mise en place et la gestion des clefs cryptographiques + * + * Copyright (C) 2016 Cyrille Bagard + * + * This file is part of Chrysalide. + * + * OpenIDA 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; either version 3 of the License, or + * (at your option) any later version. + * + * OpenIDA 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 Foobar. If not, see <http://www.gnu.org/licenses/>. + */ + + +#ifndef _ANALYSIS_DB_KEYMGN_H +#define _ANALYSIS_DB_KEYMGN_H + + +#include <stdbool.h> + + + +/* S'assure que l'utilisateur dispose de clefs RSA. */ +bool ensure_user_has_rsa_keys(void); + + + +#endif /* _ANALYSIS_DB_KEYMGN_H */ |