Escribiendo módulo anfitriones NSS una costumbre

votos
0

Estoy tratando de poner en práctica una costumbre nssmódulo para la getent hostsbúsqueda. Con base en glibc resolv/nss-dns/dns-host.cy de gnunet src/gns/nss/nss_gns.cescribí la siguiente implementación mínima que esperaba al menos debería escribir algo a syslog - la que por desgracia no es así .

#include <netdb.h>
#include <nss.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <syslog.h>

#define _nss_lash_gethostbyname2_r _nss_lash_gethostbyname_r
#define _nss_lash_gethostbyname3_r _nss_lash_gethostbyname_r
#define _nss_lash_gethostbyname4_r _nss_lash_gethostbyname_r
#define _nss_lash_getcanonname_r _nss_lash_gethostbyaddr_r
#define _nss_lash_gethostbyaddr2_r _nss_lash_gethostbyaddr_r
#define _nss_lash_getnetbyname_r _nss_lash_gethostbyaddr_r
#define _nss_lash_getnetbyaddr_r _nss_lash_gethostbyaddr_r

typedef char addr[1]; 
const addr default_addrs[2] = {0x01, 0x00};

enum nss_status
_nss_lash_gethostbyname_r (const char *name, struct hostent *result,
              char *buffer, size_t buflen, int *errnop,
              int *h_errnop)
{
    syslog(LOG_WARNING, name);
    if (!strcmp(name, lash)) {
        return NSS_STATUS_UNAVAIL;
    }
    *(result->h_aliases) = 0x0;
    result->h_addrtype = AF_INET;
    result->h_length = 1;
    *(result->h_addr_list) = (char *)default_addrs;
    *errnop = 0;
    *h_errnop = NETDB_SUCCESS; 
    return NSS_STATUS_SUCCESS;      
}

enum nss_status
_nss_lash_gethostbyaddr_r (const char *name, struct hostent *result,
              char *buffer, size_t buflen, int *errnop,
              int *h_errnop)
{
    syslog(LOG_ERR, name);
    if (!strcmp(name, lash)) {
        return NSS_STATUS_UNAVAIL;
    }
    *(result->h_aliases) = 0x0;
    result->h_addrtype = AF_INET;
    result->h_length = 1;
    *(result->h_addr_list) = (char *)default_addrs;
    *errnop = 0;
    *h_errnop = NETDB_SUCCESS; 
    return NSS_STATUS_SUCCESS;      

}

stracemuestra que el /lib/libnss_lash.so.2archivo está siendo abierto con éxito. Sin embargo, el valor de retorno de la nssbúsqueda es NSS_UNAVAIL/ ENOENT.

Alguien tiene alguna pista sobre lo que me falta?

Publicado el 13/02/2020 a las 23:58
fuente por usuario
En otros idiomas...                            

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more