Blame src/util.c

Packit 728676
/* Copyright (C) 2017 mod_auth_gssapi contributors - See COPYING for (C) terms */
Packit 728676
Packit 728676
#include "mod_auth_gssapi.h"
Packit 728676
Packit 728676
#define NSS_BUF_MIN 1024
Packit 728676
#define NSS_BUF_MAX 1024*1024
Packit 728676
static char *get_buf(char *cur, size_t *len)
Packit 728676
{
Packit 728676
    if (*len == 0) {
Packit 728676
        *len = NSS_BUF_MIN;
Packit 728676
    } else {
Packit 728676
        *len *= 2;
Packit 728676
    }
Packit 728676
    if (*len > NSS_BUF_MAX) {
Packit 728676
        *len = 0; /* will free the buf and return NULL */
Packit 728676
    }
Packit 728676
    return realloc(cur, *len);
Packit 728676
}
Packit 728676
Packit 728676
int mag_get_user_uid(const char *name, uid_t *uid)
Packit 728676
{
Packit 728676
    struct passwd pwd, *user;
Packit 728676
    size_t buflen = 0;
Packit 728676
    char *buf = NULL;
Packit 728676
    int ret;
Packit 728676
Packit 728676
    do {
Packit 728676
        buf = get_buf(buf, &buflen);
Packit 728676
        if (buf == NULL || buflen == 0) {
Packit 728676
            ret = ENOMEM;
Packit 728676
            break;
Packit 728676
        }
Packit 728676
        ret = getpwnam_r(name, &pwd, buf, buflen, &user);
Packit 728676
    } while (ret == ERANGE);
Packit 728676
    if (ret != 0 || user != &pwd) {
Packit 728676
        ret = (ret == 0) ? EINVAL : ret;
Packit 728676
    } else {
Packit 728676
        *uid = user->pw_uid;
Packit 728676
    }
Packit 728676
    free(buf);
Packit 728676
    return ret;
Packit 728676
}
Packit 728676
Packit 728676
int mag_get_group_gid(const char *name, gid_t *gid)
Packit 728676
{
Packit 728676
    struct group grp, *group;
Packit 728676
    size_t buflen = 0;
Packit 728676
    char *buf = NULL;
Packit 728676
    int ret;
Packit 728676
Packit 728676
    do {
Packit 728676
        buf = get_buf(buf, &buflen);
Packit 728676
        if (buf == NULL || buflen == 0) {
Packit 728676
            ret = ENOMEM;
Packit 728676
            break;
Packit 728676
        }
Packit 728676
        ret = getgrnam_r(name, &grp, buf, buflen, &group);
Packit 728676
    } while (ret == ERANGE);
Packit 728676
    if (ret != 0 || group != &grp) {
Packit 728676
        ret = (ret == 0) ? EINVAL : ret;
Packit 728676
    } else {
Packit 728676
        *gid = group->gr_gid;
Packit 728676
    }
Packit 728676
    free(buf);
Packit 728676
    return ret;
Packit 728676
}
Packit 728676
Packit 728676
bool mag_strbuf_equal(const char *str, gss_buffer_t buf)
Packit 728676
{
Packit 728676
    if (strncmp(str, buf->value, buf->length) != 0) return false;
Packit 728676
    return buf->length == strlen(str);
Packit 728676
}