Merge pull request #8 from yoboujon/yohan

Yohan
This commit is contained in:
sparis1206 2023-01-16 15:46:52 +01:00 committed by GitHub
commit d6ac78e6ad
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 147 additions and 40 deletions

29
header/bal.h Normal file
View file

@ -0,0 +1,29 @@
#ifndef HEADER_BAL
#define HEADER_BAL
#include "tsock.h"
typedef struct{
char *data;
int tailleData;
int idEmeteur;
}messageBAL;
struct elementMessage{
messageBAL * messageBALActuel;
struct elementMessage * suiv;
};
struct listeMessage{
struct elementMessage * debut;
struct elementMessage * courant;
struct elementMessage * fin;
};
messageBAL * creeMessage(char *data,int idEmeteur);
struct elementMessage * initElementMessage(void);
struct listeMessage initListeMessage(void);
void ajoutListe(struct listeMessage * listeActuel,messageBAL * leMessage);
void afficheListeMessage(struct listeMessage listeActuel);
#endif

View file

@ -2,6 +2,8 @@
#define HEADER_PUIT #define HEADER_PUIT
#include "tsock.h" #include "tsock.h"
int launchPuit(int nombreMessage,int tailleMessage,int isTCP);
int launchPuit(int nombreMessage,int tailleMessage,int isTCP,int port,char * ipAddress);
int receiveMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP); int receiveMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP);
#endif #endif

View file

@ -2,7 +2,7 @@
#define HEADER_SOURCE #define HEADER_SOURCE
#include "tsock.h" #include "tsock.h"
int launchSource(int nombreMessage,int tailleMessage,int isTCP); int launchSource(int nombreMessage,int tailleMessage,int isTCP,int port,char * ipAddress);
int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP); int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in * socketStruct, int sizeSocketStruct, int isTCP);
#endif #endif

View file

@ -11,14 +11,13 @@
#include <netinet/in.h> #include <netinet/in.h>
#include <netdb.h> #include <netdb.h>
#include <errno.h> #include <errno.h>
#include <arpa/inet.h>
void setNbMessage(int * nb, int source); void setNbMessage(int * nb, int source);
void printInfo(int nb, int source, int portNumber, char ipAddress[]); void printInfo(int source, int isTCP, int nbMessage, int taille, int portNumber, char ipAddress[]);
void initStructSocket(struct sockaddr_in *socketServerTemp, int source); void initStructSocket(struct sockaddr_in *socketTempStruct, int source, int port, char * ipAddress);
void getNonOtpArgs(char ** argv, int argc, int portNumber, char * ipAddress[]); void getNonOtpArgs(char ** argv, int argc, int * portNumber, char * ipAddress[]);
void formatText(char * actualMessage, int num, int tailleMessage, char messageChar); void formatText(char * actualMessage, int num, int tailleMessage, char messageChar);
int exitMax(int var,int tailleMax); int exitMax(int var,int tailleMax);
#define PORT_NUM 9000
#endif #endif

57
src/bal.c Normal file
View file

@ -0,0 +1,57 @@
#include "../header/bal.h"
int main(void){
struct listeMessage l = initListeMessage();
messageBAL * messageBAL = creeMessage("Renvoi moi mon pdf asap. -Simon",1);
ajoutListe(&l,messageBAL);
afficheListeMessage(l);
return 0;
}
messageBAL * creeMessage(char *data,int idEmeteur)
{
messageBAL * message = malloc(sizeof(messageBAL));
message->idEmeteur=idEmeteur;
message->tailleData=strlen(data);
message->data=(char*)malloc(sizeof(char)*message->tailleData);
strcpy(message->data,data);
return message;
}
struct elementMessage * initElementMessage(void)
{
struct elementMessage * returnElement = malloc(sizeof(struct elementMessage));
returnElement->messageBALActuel = creeMessage("",0);
returnElement->suiv = NULL;
return returnElement;
}
struct listeMessage initListeMessage(void)
{
struct listeMessage l;
l.debut=initElementMessage();
l.fin=initElementMessage();
l.courant=initElementMessage();
return l;
}
void ajoutListe(struct listeMessage * listeActuel,messageBAL * leMessage)
{
struct elementMessage * elementActuel = malloc(sizeof(struct elementMessage));
elementActuel->messageBALActuel=leMessage;
elementActuel->suiv=listeActuel->courant;
listeActuel->debut=elementActuel;
listeActuel->courant=elementActuel;
}
void afficheListeMessage(struct listeMessage listeActuel)
{
struct elementMessage * elementFinal = listeActuel.fin;
struct elementMessage * elementCourant = listeActuel.courant;
while(elementCourant->suiv != elementFinal->suiv)
{
printf("%s\n",elementCourant->messageBALActuel->data);
elementCourant=elementCourant->suiv;
}
}

View file

@ -8,19 +8,19 @@ int main (int argc, char **argv)
char *ipAddress; char *ipAddress;
extern char *optarg; extern char *optarg;
extern int optind; extern int optind;
int source = -1, nb_message = -1, c, tcp=1, port=9000, tailleMessage=-1; /* Nb de messages à envoyer ou à recevoir, par défaut : 10 en émission, infini en réception */ int source = -1, nb_message = -1, c, tcp=1, port=-1, tailleMessage=30; /* Nb de messages à envoyer ou à recevoir, par défaut : 10 en émission, infini en réception */
while ((c = getopt(argc, argv, "pn:sul:")) != -1) { while ((c = getopt(argc, argv, "pn:sul:")) != -1) {
switch (c) { switch (c) {
case 'p': case 'p':
if (source != -1) { if (source != -1) {
printf(usageChar); printf("%s",usageChar);
exit(1); exit(1);
} }
source = 0; source = 0;
break; break;
case 's': case 's':
if (source != -1) { if (source != -1) {
printf(usageChar); printf("%s",usageChar);
exit(1) ; exit(1) ;
} }
source = 1; source = 1;
@ -36,32 +36,39 @@ int main (int argc, char **argv)
tcp=0; tcp=0;
break; break;
default: default:
printf(usageChar); printf("%s",usageChar);
break; break;
} }
} }
if (source == -1) { if (source == -1) {
printf("-p|-s non present !\n"); printf("-p|-s non present !\n");
printf(usageChar); printf("%s",usageChar);
exit(1); exit(1);
} }
if(argc != optind+2)
{
printf("ip ou port non present !\n");
printf("%s",usageChar);
exit(1);
}
if(tailleMessage == -1) if(tailleMessage == -1)
{ {
tailleMessage = 30; tailleMessage = 30;
} }
getNonOtpArgs(argv, argc, &port, &ipAddress);
getNonOtpArgs(argv, argc, port, &ipAddress);
setNbMessage(&nb_message,source); setNbMessage(&nb_message,source);
printInfo(nb_message,source,port,ipAddress); printInfo(source,tcp,nb_message,tailleMessage,port,ipAddress);
if(source) if(source)
{ {
//printf("Source : %d\n",nb_message); //printf("Source : %d\n",nb_message);
launchSource(nb_message,tailleMessage,tcp); launchSource(nb_message,tailleMessage,tcp,port,ipAddress);
} }
else else
{ {
//printf("Puit : %d\n",nb_message); //printf("Puit : %d\n",nb_message);
launchPuit(nb_message,tailleMessage,tcp); launchPuit(nb_message,tailleMessage,tcp,port,ipAddress);
} }
return(EXIT_SUCCESS);
} }

View file

@ -1,6 +1,6 @@
#include "../header/puit.h" #include "../header/puit.h"
int launchPuit(int nombreMessage,int tailleMessage,int isTCP) int launchPuit(int nombreMessage,int tailleMessage,int isTCP,int port,char * ipAddress)
{ {
int sock,socketType; int sock,socketType;
struct sockaddr_in socketPuit; struct sockaddr_in socketPuit;
@ -11,7 +11,7 @@ int launchPuit(int nombreMessage,int tailleMessage,int isTCP)
perror("[tsock] : fonction socket() : echec creation du socket\n"); perror("[tsock] : fonction socket() : echec creation du socket\n");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
initStructSocket(&socketPuit,0); initStructSocket(&socketPuit,0,port,ipAddress);
if (bind(sock, (struct sockaddr *)&socketPuit, sizeof(socketPuit)) < 0 ) if (bind(sock, (struct sockaddr *)&socketPuit, sizeof(socketPuit)) < 0 )
{ {
perror("[tsock] : fonction bind() : echec du lien avec socket serveur.\n"); perror("[tsock] : fonction bind() : echec du lien avec socket serveur.\n");

View file

@ -1,9 +1,9 @@
#include "../header/source.h" #include "../header/source.h"
int launchSource(int nombreMessage,int tailleMessage,int isTCP) int launchSource(int nombreMessage,int tailleMessage,int isTCP,int port,char * ipAddress)
{ {
int sock,socketType;
struct sockaddr_in socketSource; struct sockaddr_in socketSource;
int sock,socketType;
socketType = (isTCP) ? SOCK_STREAM : SOCK_DGRAM; socketType = (isTCP) ? SOCK_STREAM : SOCK_DGRAM;
if((sock=socket(AF_INET,socketType,0)) == -1) if((sock=socket(AF_INET,socketType,0)) == -1)
@ -11,21 +11,26 @@ int launchSource(int nombreMessage,int tailleMessage,int isTCP)
perror("[tsock] : fonction socket() : echec creation du socket\n"); perror("[tsock] : fonction socket() : echec creation du socket\n");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
initStructSocket(&socketSource,1); initStructSocket(&socketSource,1,port,ipAddress);
if(isTCP) if(isTCP)
{ {
connect(sock,(struct sockaddr *)&socketSource,(socklen_t)sizeof(socketSource)); int connectStatus;
sendMultipleData(nombreMessage,tailleMessage,sock,socketSource,isTCP); if((connectStatus = connect(sock,(struct sockaddr *)&socketSource,(socklen_t)sizeof(socketSource))) == -1)
{
perror("[tsock] : fonction connect() : echec connexion\n");
exit(EXIT_FAILURE);
};
sendMultipleData(nombreMessage,tailleMessage,sock,&socketSource,sizeof(socketSource),isTCP);
} }
else else
{ {
sendMultipleData(nombreMessage,tailleMessage,sock,socketSource,isTCP); sendMultipleData(nombreMessage,tailleMessage,sock,&socketSource,sizeof(socketSource),isTCP);
} }
close(sock); close(sock);
return 0; return 0;
} }
int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP) int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in * socketStruct, int sizeSocketStruct, int isTCP)
{ {
int longueurEmis; int longueurEmis;
char messageChar='a'; char messageChar='a';
@ -35,11 +40,17 @@ int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct soc
formatText(sendingMessage,i,tailleMessage,messageChar); formatText(sendingMessage,i,tailleMessage,messageChar);
if(isTCP) if(isTCP)
{ {
longueurEmis = write(sock,sendingMessage,sizeof(sendingMessage)); longueurEmis = write(sock,sendingMessage,tailleMessage);
} }
else else
{ {
longueurEmis = sendto(sock, sendingMessage, tailleMessage, 0, (struct sockaddr*)&socketStruct, sizeof(socketStruct)); longueurEmis = sendto(sock,sendingMessage,tailleMessage,0,(struct sockaddr*)socketStruct, sizeSocketStruct);
}
if(longueurEmis == -1)
{
perror("[tsock] : fonction sendto()/write() : echec d'envoi\n");
exit(EXIT_FAILURE);
} }
sendingMessage[tailleMessage]='\0'; sendingMessage[tailleMessage]='\0';
printf("Source\tEnvoi n°%d (%d) :\t[%s]\n",i+1,longueurEmis,sendingMessage); printf("Source\tEnvoi n°%d (%d) :\t[%s]\n",i+1,longueurEmis,sendingMessage);

View file

@ -8,32 +8,34 @@ void setNbMessage(int * nb, int source)
} }
} }
void printInfo(int nb, int source, int portNumber, char ipAddress[]) void printInfo(int source, int isTCP, int nbMessage, int taille, int portNumber, char ipAddress[])
{ {
if(source) if(source)
{ {
printf("tsock lance en mode source, nombre de tampons à envoyer : %d\nPort : %d\t Adresse IP : %s\n", nb, portNumber, ipAddress); printf("tsock lance en mode source, nombre de messages à envoyer : %d\nTaille des messages : %d\nPort : %d\t Adresse IP : %s\n",nbMessage,taille,portNumber,ipAddress);
isTCP==1 ? printf("Mode de transmission : TCP\n") : printf("Mode de transmission : UDP\n");
} }
else else
{ {
printf("tsock lance en mode puit, nombre de tampons à recevoir :"); printf("tsock lance en mode puit, nombre de messages à recevoir :");
nb != -1 ? printf("%d\n", nb) : printf("infini\n"); nbMessage != -1 ? printf("%d\n", nbMessage) : printf("infini\n");
printf("Port : %d\n",portNumber); printf("Taille des messages : %d\nPort : %d\t Adresse IP : %s\n",taille,portNumber,ipAddress);
isTCP==1 ? printf("Mode de transmission : TCP\n") : printf("Mode de transmission : UDP\n");
} }
} }
void initStructSocket(struct sockaddr_in *socketTempStruct, int source) void initStructSocket(struct sockaddr_in *socketTempStruct, int source, int port, char * ipAddress)
{ {
memset(socketTempStruct, 0, sizeof(*socketTempStruct)); memset(socketTempStruct, 0, sizeof(*socketTempStruct));
socketTempStruct->sin_family=AF_INET; socketTempStruct->sin_family=AF_INET;
socketTempStruct->sin_port=htons(PORT_NUM); socketTempStruct->sin_port=htons(port);
if(source) if(source)
{ {
struct hostent *hp; struct hostent *hp;
if((hp = gethostbyname("localhost")) == NULL) if((hp = gethostbyname(ipAddress)) == NULL)
{ {
printf("erreur gethostbyname\n"); printf("erreur gethostbyname\n");
exit(1); exit(EXIT_FAILURE);
} }
memcpy((char*)&(socketTempStruct->sin_addr.s_addr),hp->h_addr_list[0],hp->h_length); memcpy((char*)&(socketTempStruct->sin_addr.s_addr),hp->h_addr_list[0],hp->h_length);
} }
@ -43,9 +45,9 @@ void initStructSocket(struct sockaddr_in *socketTempStruct, int source)
} }
} }
void getNonOtpArgs(char ** argv, int argc, int portNumber, char ** ipAddress) void getNonOtpArgs(char ** argv, int argc, int * portNumber, char ** ipAddress)
{ {
portNumber = atoi(argv[argc-2]); *portNumber = atoi(argv[argc-2]);
*ipAddress = NULL; *ipAddress = NULL;
*ipAddress = (char *)malloc(sizeof(argv[argc-1])); *ipAddress = (char *)malloc(sizeof(argv[argc-1]));
strcpy(*ipAddress,argv[argc-1]); strcpy(*ipAddress,argv[argc-1]);