mirror of
https://github.com/yoboujon/tsock.git
synced 2025-06-08 22:10:50 +02:00
87 lines
No EOL
4.4 KiB
C
87 lines
No EOL
4.4 KiB
C
#ifndef HEADER_PUIT
|
|
#define HEADER_PUIT
|
|
|
|
#include "tsock.h"
|
|
#include "bal.h"
|
|
#include "iptable.h"
|
|
|
|
/**
|
|
* @brief Fonction principale pour le puit. Peut lancer en mode TCP/UDP avec la fonction receiveMultipleData()
|
|
* Vérifie si la variable isBAL est à 1 -> active le mode boite aux lettres avec la fonction du même nom
|
|
*
|
|
* @param nombreMessage int, le nombre de message à envoyer.
|
|
* @param tailleMessage int, la taille de chacun de ces messages.
|
|
* @param isTCP int, 1 -> TCP, 0 -> UDP
|
|
* @param port int, numéro du port
|
|
* @param isBAL int, 1-> Mode Boite aux Lettres
|
|
* @return int 0-> si réussite, autre sinon
|
|
*/
|
|
int launchPuit(int nombreMessage,int tailleMessage,int isTCP,int port,int isBAL);
|
|
|
|
/**
|
|
* @brief Pour un nombre de message donné (-1 -> infini) recevra des messages avec une taille précise.
|
|
* à l'aide de isTCP utilise différente primitive (listen, accept et read pour TCP, recvfrom pour UDP)
|
|
* Dans le cas d'UDP si nombreMessage = -1 (infini) écoutera à l'infini la source. Pour TCP fermera la connexion
|
|
* une fois la connexion finie [A améliorer].
|
|
*
|
|
* @param nombreMessage int, le nombre de message à envoyer.
|
|
* @param tailleMessage int, la taille de chacun de ces messages.
|
|
* @param sock int, socket premettant d'utiliser la primitive readRecvFrom().
|
|
* @param socketStruct struct sockaddr_in , la structure du socket.
|
|
* @param isTCP int, 1 -> TCP, 0 -> UDP.
|
|
* @return int 0 si réussi.
|
|
*/
|
|
int receiveMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP);
|
|
|
|
/**
|
|
* @brief Créer une structure listeBAL pour stocker les différentes lettres des emetteurs.
|
|
* Uniquement en mode TCP lit la première couche protocolaire pour connaître le mode de la source.
|
|
* Si MODE_RECEPTEUR alors la primitive receptionRecepteur est lancée.
|
|
* Si MODE_EMIS alors la primitive receptionEmetteur est lancée.
|
|
* Ferme le socket TCP une fois les messages reçues et relance la connexion avec listen() et accept().
|
|
*
|
|
* @param socketStruct struct sockaddr_in *, la structure du socket sous forme de pointeur
|
|
* @param socketType SOCK_STREAM pour TCP ou SOCK_DGRAM pour UDP
|
|
* @param port int, numéro du port
|
|
* @param ipAddress char *, adresse IP
|
|
*/
|
|
void modeBoiteAuxLettres(struct sockaddr_in socketStruct, int socketType, int port, char * ipAddress);
|
|
|
|
/**
|
|
* @brief à partir d'un socket, lit le message reçu et l'ajoute dans la boite aux lettre donnée en paramètre.
|
|
*
|
|
* @param sock int, socket premettant d'utiliser la primitive read()
|
|
* @param tailleMessagePrevu int, taille du message prévu donné par la couche protocolaire de l'application
|
|
* @param tailleMessageRecu int*, taille réel donné par read()
|
|
* @param emetteur int, numéro de l'émetteur
|
|
* @param recepteur int, numéro du recepteur
|
|
* @param boiteAuxLettres struct listeBAL*, pointeur visant la boite aux lettres
|
|
*/
|
|
void receptionEmetteur(int sock, int tailleMessagePrevu, int * tailleMessageRecu, int emetteur, int recepteur, struct listeBAL *boiteAuxLettres);
|
|
|
|
/**
|
|
* @brief à partir d'un socket, renvoi les messages dans la boite aux lettres pour un recepteur precis.
|
|
*
|
|
* @param sock int, socket premettant d'utiliser la primitive write().
|
|
* @param recepteur int, id du recepteur.
|
|
* @param boiteAuxLettres struct listeBAL, la boite aux lettres à renvoyer.
|
|
*/
|
|
int receptionRecepteur(int sock, int socketType, struct sockaddr_in socketStruct, int port, int recepteur, struct listeBAL boiteAuxLettres);
|
|
|
|
/**
|
|
* @brief Permet, à partir de isTCP de choisir la méthode d'envoi.
|
|
*
|
|
* @param sock int,socket premettant d'utiliser la primitive read()/recvfrom().
|
|
* @param socketStruct struct sockaddr_in, la structure du socket avec l'ip et le port.
|
|
* @param longueurRecu int, sizeof(socketStruct)
|
|
* @param messageRecu char*, la chaîne de caractère qui recevra le message, doit être allouée
|
|
* @param tailleMessage int, la longueur donnée par l'utilisateur
|
|
* @param isTCP int, 1 -> TCP, 0 -> UDP
|
|
* @param i int, fonctionne comme un count pour le printf()
|
|
* @return int, renvoi la longueur n reçue par TCP/UDP.
|
|
*/
|
|
int readRecvFrom(int sock, struct sockaddr_in socketStruct, int longueurRecu, char * messageRecu, int tailleMessage, int isTCP, int i);
|
|
|
|
int getEmetteurId(struct sockaddr_in socketStruct, struct listeIpTable * tabledIp);
|
|
|
|
#endif |