X-Git-Url: https://git.llucax.com/z.facultad/75.74/practicos.git/blobdiff_plain/037c7a6a269f053f09e3ebab3c28e4453b576d18..HEAD:/practicas/pipi/src/resolvproto.h diff --git a/practicas/pipi/src/resolvproto.h b/practicas/pipi/src/resolvproto.h index 826fa38..b554bcc 100644 --- a/practicas/pipi/src/resolvproto.h +++ b/practicas/pipi/src/resolvproto.h @@ -2,35 +2,57 @@ #define _RESOLVPROTO_H_ #include "ipaddr.h" +#include "ipin.h" +#include "ipout.h" #include #include #include #include -/// Petición del resolver a un nameserver -struct ResolvProtoRequest +/// Número de protocolo del resolver +#define RESOLV_PROTO 59 + +/// Tipo de petición +enum rp_pkt_type_t { + // requests + RP_REQ_DIRECT, ///> Búsqueda directa (inter nameservers) + RP_REQ_RECURSIVE, ///> Búsqueda recursiva (para resolvers) + // responses + RP_RES_A, ///> OK, se devolvió un registro A + RP_RES_NS, ///> OK, se devolvió un registro NS (sólo en directo) + RP_RES_NOTFOUND ///> No se encontró +}; - /// Tipo de petición, por ahora sólo QUERY - enum { TYPE_QUERY }; +/// Petición de un nameserver +/// +------------+------------+------------+ +/// | QUERY_TYPE | SIZE | NAME | +/// +------------+------------+------------+ +/// /-- 1 byte --/- 2 bytes --/- variable -/ +struct ResolvProtoRequest +{ - /// Tipo de petición, por ahora sólo QUERY - uint8_t type; + /// Tipo de petición (de tipo rp_pkt_type_t) + uint8_t query_type; /// Nombre a buscar std::string name; - /// Constructor - ResolvProtoRequest(int fd); - - /// Constructor - ResolvProtoRequest(std::string name, uint8_t type = TYPE_QUERY); + /// Constructores + ResolvProtoRequest(std::string name, rp_pkt_type_t query_type); + ResolvProtoRequest(std::string buf); /// Envía por socket - void send(int sockfd) const throw (std::runtime_error); + void send(IPOut& ipo) const throw (std::runtime_error); /// Recibe por socket - void recv(int sockfd) throw (std::runtime_error); + void recv(IPIn& ipi) throw (std::runtime_error); + + /// Obtiene tamaño del paquete + size_t packet_size() const; + + /// Convierte a un string + operator std::string () const; }; @@ -38,31 +60,41 @@ struct ResolvProtoRequest std::ostream& operator<< (std::ostream& os, const ResolvProtoRequest& rpr); -/// Respuesta del resolver a un nameserver +/// Respuesta de un nameserver +/// +-----------+-----------+-----------+-----------+-----------+-----------+ +/// | RET | TTL | COUNT | IP 1 | ... | IP N | +/// +-----------+-----------+-----------+-----------+-----------+-----------+ +/// /-- 1 byte -/- 4 bytes -/-- 1 byte -/- 4 bytes -/- 4 bytes -/- 4 bytes -/ struct ResolvProtoResponse { - /// Resultado de la respuesta - enum ret_t { RET_OK, RET_NOTFOUND, RET_TIMEOUT }; - - /// Resultado de la respuesta + /// Resultado de la respuesta (de tipo rp_pkt_type_t) uint8_t ret; + /// TTL (sólo útil para búsquedas (inter nameserver) + uint32_t ttl; + /// IPs devueltas typedef std::vector< IPAddr > ipvec_t; ipvec_t ips; - /// Constructor - ResolvProtoResponse(int fd); - - /// Constructor - ResolvProtoResponse(ret_t ret); + /// Constructores + ResolvProtoResponse(); + ResolvProtoResponse(rp_pkt_type_t ret, uint32_t ttl = 0, + const ipvec_t& ips = ipvec_t()); + ResolvProtoResponse(std::string buf); /// Envía por socket - void send(int sockfd) const throw (std::runtime_error); + void send(IPOut& ipo) const throw (std::runtime_error); /// Recibe por socket - void recv(int sockfd) throw (std::runtime_error); + void recv(IPIn& ipi) throw (std::runtime_error); + + /// Obtiene tamaño del paquete + size_t packet_size() const; + + /// Convierte a un string + operator std::string () const; };