Easy-sauvegarde

Soyez le premier à donner votre avis sur cette source.

Snippet vu 7 990 fois - Téléchargée 30 fois

Contenu du snippet

Voici ma toute première source !!! J'ai appris le C par moi même. Ce programme n'apporte rien de véritablement nouveau ni de spécial. Je voudrais juste avoir des critiques afin de progresser. Et surtout, allez-y !!!

Donc ce petit utilitaire permet de sauvegarder la configuration de Linux (Ubuntu) ! Il sauvegarde quatres fichiers:
1) /etc/X11/xorg.conf
2) /etc/environment
3) /etc/locale.gen
4)/etc/apt/sources.list

Puis permet de les restaurer par la suite. Je vous répète ceci est ma toute PREMIERE source mais que cela nous empêche pas de la critiquer.

Merci, bye...

Source / Exemple :


//Inclusion des librairies
#include <stdio.h>
#include <string.h>
#include <gtk/gtk.h>
#include <stdlib.h>

//Déclaration des constantes des noms des fichiers
#define CHEMIN_XORG "/etc/X11/xorg.conf"
#define CHEMIN_ENVIRONMENT "/etc/environment"
#define CHEMIN_LOCAL "/etc/locale.gen"
#define CHEMIN_SOURCES "/etc/apt/sources.list"

//Déclaration des différents textes présent dans le programme
#define TEXTE_1 TEXTE_7" vous permettra de sauvegarder,\nen un clique, toute la configuration de votre installation\nUbuntu et, ainsi, la restaurer lors d'une prochaine\nréinstallation."
#define TEXTE_2 "Cet utilitaire,developpé en C/Gtk, permet d'exporter la configuration systeme de votre ordinateur afin de la restaurer lorsque vous le réinstallerez.\n\nVoici la listes des fichiers sauvegardés:\n1) "CHEMIN_XORG"\n2) "CHEMIN_ENVIRONMENT"\n3) "CHEMIN_LOCAL"\n4) "CHEMIN_SOURCES"\n\nVersion: 0.0.2\nDate: 06/01/06"
#define TEXTE_3 "Où voulez-vous sauvegarder votre configuration ?"
#define TEXTE_4 "Sauvegarder"
#define TEXTE_5 "Restaurer"
#define TEXTE_6 "À propos"
#define TEXTE_7 "Easy-Sauvegarde"
#define TEXTE_8 "La sauvegarde s'est corretement déroulée"
#define TEXTE_9 "Ouvrez le dossier où se trouve la sauvegarde..."
#define TEXTE_10 "La restauration de votre configuration s'est bien déroulée.\n\nUne copie des fichiés originaux a été faite dans leurs répertoires."

#define NOM_FICHIER_SAUVEGARDE "ConfigSauvegarde"

#define ERREUR_1 "Impossible d'ouvrir le fichier. Vérifiez que vous êtes bien en administrateur."
#define ERREUR_2 "Attention:\nLe fichier de sauvegarde ne peut être réutilisé car il comporte des erreurs. Il a sans doute du être modifié entre temps."
#define ERREUR_3 "Attention:\nUn des fichiers n'a pas été trouvé sur votre ordinateur. La sauvegarde ne peut pas être faite."
#define ERREUR_4 "Attention:\nAucun fichier correspondant n'a été trouvé dans ce répertoire.\n\nLe fichier ce nomme "NOM_FICHIER_SAUVEGARDE"."

//Déclaration des procédures
void sauvegarde();
void restauration();
void a_propos();
void erreur(int erreur);

////////////////////////////////////////////////////////////////////////////////
//Fonction principale
int main(int argc, char **argv)
{
	//Déclaration des Widget
	GtkWidget *pWindow;
	GtkWidget *pVBox;
	GtkWidget *pHBox;
	GtkWidget *pLabel;
	GtkWidget *pButton[2];
	GtkWidget *pFrame;
	
	//Initiation de GTK
	gtk_init(&argc,&argv);
	
	//Création de notre fenêtre principale
	pWindow = gtk_window_new(GTK_WINDOW_TOPLEVEL);
	gtk_window_set_title(GTK_WINDOW(pWindow), TEXTE_7 );
	gtk_window_set_default_size(GTK_WINDOW(pWindow), 385, 160);
	gtk_window_set_position(GTK_WINDOW(pWindow),  GTK_WIN_POS_CENTER);
	g_signal_connect(G_OBJECT(pWindow), "destroy", G_CALLBACK(gtk_main_quit), NULL);
	gtk_container_set_border_width(GTK_CONTAINER (pWindow), 10);
	
	//Déclaration des labels
	pLabel = gtk_label_new( TEXTE_1 );
	
	//Déclaration des bouttons
	pButton[0] = gtk_button_new_with_label( TEXTE_4 );
	pButton[1] = gtk_button_new_with_label( TEXTE_5 );
	pButton[2] = gtk_button_new_with_label( TEXTE_6 );
	
	//Association des actions aux boutons
	g_signal_connect(G_OBJECT( pButton[0] ), "clicked", sauvegarde, NULL);
	g_signal_connect(G_OBJECT( pButton[1] ), "clicked", restauration, NULL);
	g_signal_connect(G_OBJECT( pButton[2] ), "clicked", a_propos, NULL);
	
	//Construction des conteneurs
	pVBox = gtk_vbox_new(FALSE, 0);
	pHBox = gtk_hbox_new(FALSE, 3);
	
	//Construction des frames
	pFrame = gtk_frame_new("Avant propos:");
	
	//Ajout dans les conteneurs
	gtk_container_add(GTK_CONTAINER(pWindow), pVBox);
	
	gtk_box_pack_start(GTK_BOX(pVBox), pFrame, false, false, 0);
	gtk_container_add(GTK_CONTAINER( pFrame ), pLabel );
	gtk_box_pack_end(GTK_BOX(pVBox), pHBox, false, false, 0);

	gtk_box_pack_start(GTK_BOX(pHBox), pButton[0], false, false, 10);
	gtk_box_pack_start(GTK_BOX(pHBox), pButton[1], false, false, 10);
	gtk_box_pack_end(GTK_BOX(pHBox), pButton[2], false, false, 10); 
	
	//Affichage de notre fenêtre
	gtk_widget_show_all(pWindow);
	
	//Lancement de notre boucle
	gtk_main();
	
	
	return 0;
}

////////////////////////////////////////////////////////////////////////////////
//Fonction de sauvegarde
void sauvegarde(){

	//Déclaration des Widget et des variables
	GtkWidget *pFileSelection;
	GtkWidget *pDialog;
	gchar *sChemin;
	char adresse[512];
	char buffer;
	int resultat_choix;
	

	
	//Création de la fenêtre du choix de l'emplacement pour la sauvegarde
	pFileSelection = gtk_file_chooser_dialog_new( TEXTE_3 ,
	   GTK_WINDOW(NULL),
	   GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
	   GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
	   GTK_STOCK_OPEN, GTK_RESPONSE_OK,
	   NULL);
	
	//Affichage de la fenêtre
	resultat_choix = gtk_dialog_run(GTK_DIALOG(pFileSelection));
	
	//Traitement du retour
	if( resultat_choix == GTK_RESPONSE_OK ){
			
		//Récupération du chemin
		sChemin = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(pFileSelection));
				
		
		//Déclaration des pointeurs FILE
		FILE *fichier_destination;
		FILE *fichier_lecture;
		
		//Création de l'adresse complète
		strcpy(adresse,sChemin);
		strcat(adresse,"/"NOM_FICHIER_SAUVEGARDE);
		
		//Libération de la mémoire aloué pour sChemin
		g_free(sChemin);
		
		//Ouverture du fichier de destination
		fichier_destination = fopen(adresse,"w");
		
		//Ouverture de xorg en simple lecture
		fichier_lecture = fopen(CHEMIN_XORG,"r");
		
		//Vérification d'aucune erreur
		if( fichier_destination == false || fichier_lecture == false){  fclose(fichier_destination);
			                                                            remove(adresse);
			                                                            erreur(3) ; }
		
		//Ecriture premières lignes pour les informations
		if( fputs("Ce fichier a été généré par \""TEXTE_7"\".\n",fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs("Ne surtout pas le modifier. Cela pourrait abimer votre configuration\n\n\n",fichier_destination) == EOF ){ erreur(1) ; }
								   
		if( fputs("==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs(CHEMIN_XORG,fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs("\n==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
								   
		//Copie du fichier xorg
		while( ( buffer = (char)getc(fichier_lecture) ) != EOF ){ if( putc(buffer,fichier_destination) == EOF ){ erreur(1) ; } }
		
		//Changement du fichier en lecture
		fclose(fichier_lecture);
		fichier_lecture = fopen( CHEMIN_ENVIRONMENT ,"r");
		
		//Vérification d'aucune erreur
		if( fichier_lecture == false){ fclose(fichier_destination);
			                           remove(adresse);
			                           erreur(3) ; }
		
		//Indication de changement de fichier
		if( fputs("==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs( CHEMIN_ENVIRONMENT ,fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs("\n==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
		
		//Copie du fichier ENVIRONMENT
		while( ( buffer = (char)getc(fichier_lecture) ) != EOF ){ if( putc(buffer,fichier_destination) == EOF ){ erreur(1) ; } }
		
		//Changement du fichier en lecture
		fclose(fichier_lecture);
		fichier_lecture = fopen( CHEMIN_LOCAL ,"r");
		
		//Vérification d'aucune erreur
		if( fichier_lecture == false){ fclose(fichier_destination);
			                           remove(adresse);
			                           erreur(3) ; }
									   
									   
		//Indication de changement de fichier
        if( fputs("==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
        if( fputs( CHEMIN_LOCAL ,fichier_destination) == EOF ){ erreur(1) ; }
        if( fputs("\n==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
        
		
		//Copie du fichier ENVIRONMENT
		while( ( buffer = (char)getc(fichier_lecture) ) != EOF ){ if( putc(buffer,fichier_destination) == EOF ){ erreur(1) ; } }
				
		//Changement du fichier en lecture
		fclose(fichier_lecture);
		fichier_lecture = fopen( CHEMIN_SOURCES ,"r");
		
		//Vérification d'aucune erreur
		if( fichier_lecture == false){ fclose(fichier_destination);
			                           remove(adresse);
			                           erreur(3) ; }
		
		//Indication de changement de fichier
		if( fputs("==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs( CHEMIN_SOURCES ,fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs("\n==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
		
		//Copie du fichier SOURCES
		while( ( buffer = (char)getc(fichier_lecture) ) != EOF ){ if( putc(buffer,fichier_destination) == EOF ){ erreur(1) ; } }
				
		//Indication de la fin de la sauvegarde
		if( fputs("==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs("Fin\n",fichier_destination) == EOF ){ erreur(1) ; }
		if( fputs("==============================================================================\n",fichier_destination) == EOF ){ erreur(1) ; }
		
		
		//Suppresion des pointeurs FILE
		fclose(fichier_destination);
		fclose(fichier_lecture);
		
		//Affichage du message de confirmation
		pDialog = gtk_message_dialog_new(GTK_WINDOW(pFileSelection),
                  GTK_DIALOG_MODAL,
                  GTK_MESSAGE_INFO,
                  GTK_BUTTONS_OK,
                  TEXTE_8 );
		gtk_dialog_run(GTK_DIALOG(pDialog));
		gtk_widget_destroy(pDialog);
		
		}
	
	//Destruction de la fenêtre
	gtk_widget_destroy(pFileSelection);	
	
	return;
}

////////////////////////////////////////////////////////////////////////////////
//Fonction A propos
void restauration(){
	
	//Déclaration des Widget et des variables
	GtkWidget *pFileSelection;
	GtkWidget *pDialog;
	gchar *sChemin;
	char adresse[512];
	char buffer;
	int resultat_choix;
	int compteur = 0;
	char *memoire;
	char *debut;
	char *fin;

	
	//Création de la fenêtre du choix de l'emplacement pour la sauvegarde
	pFileSelection = gtk_file_chooser_dialog_new( TEXTE_9 ,
	   GTK_WINDOW(NULL),
	   GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
	   GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
	   GTK_STOCK_OPEN, GTK_RESPONSE_OK,
	   NULL);
	
	//Affichage de la fenêtre
	resultat_choix = gtk_dialog_run(GTK_DIALOG(pFileSelection));
	
	//Traitement du retour
	if( resultat_choix == GTK_RESPONSE_OK ){
			
		//Récupération du chemin
		sChemin = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(pFileSelection));
		
		
		//Déclaration des pointeurs FILE
		FILE *fichier;
		
		//Création de l'adresse complète
		strcpy(adresse,sChemin);
		strcat(adresse,"/"NOM_FICHIER_SAUVEGARDE);
		
		//Libération de la mémoire aloué pour sChemin
		g_free(sChemin);
		
		//Ouverture du fichier en lecture
		fichier = fopen( adresse , "r" );
		
		//Vérification d'aucune erreur
		if( fichier == false){ erreur(4) ; }
		
		//Récupération de la taille du fichier afin de le charger en mémoire
		while( getc( fichier ) !=  EOF ){ compteur++ ; }
		
		//Rembobinage du fichier
		rewind(fichier);
		
		//Allocation de la mémoire nécessaire
		memoire = (char*)malloc(compteur + 1);
		
		//On charge le fichier en mémoire
		compteur = 0;
		while( ( buffer = (char)getc( fichier ) ) !=  EOF ){

  • (memoire + compteur ) = buffer;
compteur++; } //Fermeture du fichier_lecture fclose( fichier ); //Sauvegarde des fichiers avant installation if( 0 != rename(CHEMIN_LOCAL, CHEMIN_LOCAL".bak") ){ erreur(1) ; } if( 0 != rename(CHEMIN_ENVIRONMENT, CHEMIN_ENVIRONMENT".bak") ){ erreur(1) ; } if( 0 != rename(CHEMIN_XORG, CHEMIN_XORG".bak") ){ erreur(1) ; } if( 0 != rename(CHEMIN_SOURCES, CHEMIN_SOURCES".bak") ){ erreur(1) ; } //////////////////////////////////////////////////////////////////////////////// //Restauration du fichier sources.list //Récupération du fichier CHEMIN_SOURCES debut = strstr( memoire, "==============================================================================\n"CHEMIN_SOURCES"\n==============================================================================\n"); fin = strstr( memoire, "==============================================================================\nFin\n==============================================================================\n");
  • fin = '\0';
//Vérification rapide (pas optimisé) de l'intégrité des données if( debut == NULL || fin == NULL ){ erreur(2) ; } //Ecriture du fichier CHEMIN_SOURCES compteur = strlen("==============================================================================\n"CHEMIN_SOURCES"\n==============================================================================\n"); debut = debut + compteur; fichier = fopen( CHEMIN_SOURCES, "w" ); fputs( debut, fichier ); fclose(fichier); //////////////////////////////////////////////////////////////////////////////// //Restauration du fichier locale.gen //Récupération du fichier CHEMIN_LOCAL debut = strstr( memoire, "==============================================================================\n"CHEMIN_LOCAL"\n==============================================================================\n"); fin = strstr( memoire, "==============================================================================\n"CHEMIN_SOURCES"\n==============================================================================\n");
  • fin = '\0';
//Vérification rapide (pas optimisé) de l'intégrité des données if( debut == NULL || fin == NULL ){ erreur(2) ; } //Ecriture du fichier CHEMIN_LOCAL compteur = strlen("==============================================================================\n"CHEMIN_LOCAL"\n==============================================================================\n"); debut = debut + compteur; fichier = fopen( CHEMIN_LOCAL, "w" ); fputs( debut, fichier ); fclose(fichier); //////////////////////////////////////////////////////////////////////////////// //Restauration du fichier environment //Récupération du fichier CHEMIN_ENVIRONMENT debut = strstr( memoire, "==============================================================================\n"CHEMIN_ENVIRONMENT"\n==============================================================================\n"); fin = strstr( memoire, "==============================================================================\n"CHEMIN_LOCAL"\n==============================================================================\n");
  • fin = '\0';
//Vérification rapide (pas optimisé) de l'intégrité des données if( debut == NULL || fin == NULL ){ erreur(2) ; } //Ecriture du fichier CHEMIN_ENVIRONMENT compteur = strlen("==============================================================================\n"CHEMIN_ENVIRONMENT"\n==============================================================================\n"); debut = debut + compteur; fichier = fopen( CHEMIN_ENVIRONMENT, "w" ); fputs( debut, fichier ); fclose(fichier); //////////////////////////////////////////////////////////////////////////////// //Restauration du fichier xorg.conf //Récupération du fichier CHEMIN_XORG debut = strstr( memoire, "==============================================================================\n"CHEMIN_XORG"\n==============================================================================\n"); fin = strstr( memoire, "==============================================================================\n"CHEMIN_ENVIRONMENT"\n==============================================================================\n");
  • fin = '\0';
//Vérification rapide (pas optimisé) de l'intégrité des données if( debut == NULL || fin == NULL ){ erreur(2) ; } //Ecriture du fichier CHEMIN_XORG compteur = strlen("==============================================================================\n"CHEMIN_XORG"\n==============================================================================\n"); debut = debut + compteur; fichier = fopen( CHEMIN_XORG, "w" ); fputs( debut, fichier ); fclose(fichier); //////////////////////////////////////////////////////////////////////////////// //Libération de la mémoire free(memoire); //Affichage du message de confirmation pDialog = gtk_message_dialog_new(GTK_WINDOW(pFileSelection), GTK_DIALOG_MODAL, GTK_MESSAGE_INFO, GTK_BUTTONS_OK, TEXTE_10); gtk_dialog_run(GTK_DIALOG(pDialog)); gtk_widget_destroy(pDialog); } //Destruction de la fenêtre gtk_widget_destroy(pFileSelection); } //////////////////////////////////////////////////////////////////////////////// //Fonction A propos void a_propos(){ //Déclaration des Widget GtkWidget *pDialog; //Affichage puis destruction de la fenêtre pDialog = gtk_message_dialog_new(GTK_WINDOW(NULL), GTK_DIALOG_MODAL, GTK_MESSAGE_INFO, GTK_BUTTONS_OK, TEXTE_2); gtk_dialog_run(GTK_DIALOG(pDialog)); gtk_widget_destroy(pDialog); } //////////////////////////////////////////////////////////////////////////////// //Fonction Gestion des erreurs void erreur(int erreur){ GtkWidget *pDialog; char message[256]; //Chargement du message d'erreur switch(erreur) { case 1: strcpy(message, ERREUR_1); break; case 2: strcpy(message, ERREUR_2); break; case 3: strcpy(message, ERREUR_2); break; default: strcpy(message, ERREUR_4); break; } //Affichage puis destruction de la fenêtre pDialog = gtk_message_dialog_new(GTK_WINDOW(NULL), GTK_DIALOG_MODAL, GTK_MESSAGE_INFO, GTK_BUTTONS_OK, message ); gtk_dialog_run(GTK_DIALOG(pDialog)); gtk_widget_destroy(pDialog); //On quitte le programme exit(1); }

Conclusion :


J'aimerai, par la suite; compresser le fichier généré puis vérifier son intégrité avec un md5 pas exemple...

Merci pour vos conseils...

A voir également

Ajouter un commentaire Commentaires
Messages postés
4
Date d'inscription
vendredi 2 novembre 2007
Statut
Membre
Dernière intervention
5 novembre 2007

Ton programme est vulnérable au Buffer Overflow.. Regarde (strcpy(adresse,sChemin); ) utilise plus tot strncpy pour contrôler la taille de l'input. Si tu utilise le programme en root, on peut executer du code si on exploite cette fonction.
Messages postés
1243
Date d'inscription
jeudi 31 mars 2005
Statut
Membre
Dernière intervention
3 août 2016
2
Haaaaaaaaaaaa oki. Merci pour l'adresse du tuto, en faite je savai pas qu'il falait faire un nouveau projet GTK+. Bon
heu c'est ma période d'exam (j'ai math demain arg) je verai ça après. Si besoin est tu seras tjrs quelque part sur le forum? lol
Messages postés
1243
Date d'inscription
jeudi 31 mars 2005
Statut
Membre
Dernière intervention
3 août 2016
2
En faite si, la compilation se termine, mais j'ai au bas moi une centaine d'erreur dans chaque .h de gtk :s
Messages postés
1243
Date d'inscription
jeudi 31 mars 2005
Statut
Membre
Dernière intervention
3 août 2016
2
l'ennuie c'est que j'ai donc bien installer gtk pour dev-cpp, mais lorsque je fait un include <gtk\gtk.>
Cela ne vas pas car c'est pas le bon dossier. Enfin bon je me susi arragé pour que le chemin soit bien gtk\gtk.h.

Seulement je ne sais pas ce qui ce passe, pour un minuscule projet (qui utilise mm pas encore gtk) ça mes un temps fou a compilé.
sans jamais arrivé a la fin.

Qu'est ce qui ne vas pas?
Messages postés
21
Date d'inscription
mardi 1 juin 2004
Statut
Membre
Dernière intervention
16 janvier 2006

Je te conseil ça => http://www.gtk-fr.org/wakka.php?wiki=PageAccueil.
Va dans 'Les fenêtres', il y a un exemple...
Afficher les 33 commentaires

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.