/* Editor Settings: expandtabs and use 4 spaces for indentation * ex: set softtabstop=4 tabstop=8 expandtab shiftwidth=4: * * -*- mode: c, c-basic-offset: 4 -*- */ /* * Copyright Likewise Software 2004-2008 * All rights reserved. * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 2.1 of the license, or (at * your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser * General Public License for more details. You should have received a copy * of the GNU Lesser General Public License along with this program. If * not, see . * * LIKEWISE SOFTWARE MAKES THIS SOFTWARE AVAILABLE UNDER OTHER LICENSING * TERMS AS WELL. IF YOU HAVE ENTERED INTO A SEPARATE LICENSE AGREEMENT * WITH LIKEWISE SOFTWARE, THEN YOU MAY ELECT TO USE THE SOFTWARE UNDER THE * TERMS OF THAT SOFTWARE LICENSE AGREEMENT INSTEAD OF THE TERMS OF THE GNU * LESSER GENERAL PUBLIC LICENSE, NOTWITHSTANDING THE ABOVE NOTICE. IF YOU * HAVE QUESTIONS, OR WISH TO REQUEST A COPY OF THE ALTERNATE LICENSING * TERMS OFFERED BY LIKEWISE SOFTWARE, PLEASE CONTACT LIKEWISE SOFTWARE AT * license@likewisesoftware.com */ /* * Copyright (C) Likewise Software. All rights reserved. * * Module Name: * * nss-main.c * * Abstract: * * Name Server Switch (Likewise LSASS) * * Main Entry Points * * Authors: Krishna Ganugapati (krishnag@likewisesoftware.com) * Sriram Nambakam (snambakam@likewisesoftware.com) * */ #include "lsanss.h" #include "nss-user.h" #include "nss-group.h" #include "nss-auth.h" #if defined(__LWI_FREEBSD__) static int LsaNSSFindUserById( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSFindUserByName( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSBeginEnumUsers( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSEnumUsers( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSEndEnumUsers( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSFindGroupById( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSFindGroupByName( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSBeginEnumGroups( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSEnumGroups( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSEndEnumGroups( PVOID pResult, PVOID pData, va_list ap ); static int LsaNSSGetGroupMembership( PVOID pResult, PVOID pData, va_list ap ); ns_mtab * nss_module_register( const char* pszModName, unsigned int* pLen, nss_module_unregister_fn* pFnUnregister ) { static ns_mtab fnTable[] = { { "passwd", "getpwuid_r", &LsaNSSFindUserById, 0}, { "passwd", "getpwnam_r", &LsaNSSFindUserByName, 0}, { "passwd", "setpwent", &LsaNSSBeginEnumUsers, 0}, { "passwd", "getpwent_r", &LsaNSSEnumUsers, 0}, { "passwd", "endpwent", &LsaNSSEndEnumUsers, 0}, { "group", "getgrnam_r", &LsaNSSFindGroupByName, 0}, { "group", "getgrgid_r", &LsaNSSFindGroupById, 0}, { "group", "setgrent", &LsaNSSBeginEnumGroups, 0}, { "group", "getgrent_r", &LsaNSSEnumGroups, 0}, { "group", "endgrent", &LsaNSSEndEnumGroups, 0}, { "group", "getgroupmembership", &LsaNSSGetGroupMembership, 0} }; *pLen = sizeof(fnTable)/sizeof(fnTable[0]); *pFnUnregister = NULL; return fnTable; } static int LsaNSSFindUserById( PVOID pResult, PVOID pData, va_list ap ) { int ret = 0; uid_t uid = 0; struct passwd* pResultUser = NULL; PSTR pszBuf = NULL; size_t stBufLen = 0; PINT pErrorNumber = 0; uid = va_arg(ap, uid_t); pResultUser = (struct passwd*)va_arg(ap, struct passwd *); pszBuf = (PSTR)va_arg(ap, char*); stBufLen = (size_t)va_arg(ap, size_t); pErrorNumber = (PINT)va_arg(ap, int *); ret = _nss_lsass_getpwuid_r( uid, pResultUser, pszBuf, stBufLen, pErrorNumber); if(pResult) { *((struct passwd**)pResult) = ret != NSS_STATUS_SUCCESS ? NULL : pResultUser; } return ret; } static int LsaNSSFindUserByName( PVOID pResult, PVOID pData, va_list ap ) { int ret = 0; PCSTR pszLoginId = NULL; struct passwd* pResultUser = NULL; PSTR pszBuf = NULL; size_t stBufLen = 0; PINT pErrorNumber = NULL; pszLoginId = va_arg(ap, PCSTR); pResultUser = (struct passwd*)va_arg(ap, struct passwd *); pszBuf = (PSTR)va_arg(ap, char*); stBufLen = (size_t)va_arg(ap, size_t); pErrorNumber = (PINT)va_arg(ap, int *); ret = _nss_lsass_getpwnam_r( pszLoginId, pResultUser, pszBuf, stBufLen, pErrorNumber); if(pResult) { *((struct passwd**)pResult) = ret != NSS_STATUS_SUCCESS ? NULL : pResultUser; } return ret; } static int LsaNSSBeginEnumUsers( PVOID pResult, PVOID pData, va_list ap ) { int ret = _nss_lsass_setpwent(); return ret; } static int LsaNSSEnumUsers( PVOID pResult, PVOID pData, va_list ap ) { int ret = 0; struct passwd* pResultUser = NULL; PSTR pszBuf = NULL; size_t stBufLen = 0; PINT pErrorNumber = NULL; pResultUser = (struct passwd*)va_arg(ap, struct passwd*); pszBuf = (PSTR)va_arg(ap, char*); stBufLen = (size_t)va_arg(ap, size_t); pErrorNumber = (PINT)va_arg(ap, int*); ret = _nss_lsass_getpwent_r( pResultUser, pszBuf, stBufLen, pErrorNumber); if(pResult) { *((struct passwd**)pResult) = ret != NSS_STATUS_SUCCESS ? NULL : pResultUser; } return ret; } static int LsaNSSEndEnumUsers( PVOID pResult, PVOID pData, va_list ap ) { int ret = _nss_lsass_endpwent(); return ret; } static int LsaNSSFindGroupById( PVOID pResult, PVOID pData, va_list ap ) { int ret = 0; gid_t gid = 0; struct group* pResultGroup = NULL; PSTR pszBuf = NULL; size_t stBufLen = 0; PINT pErrorNumber = 0; gid = va_arg(ap, gid_t); pResultGroup = (struct group*)va_arg(ap, struct group *); pszBuf = (PSTR)va_arg(ap, char*); stBufLen = (size_t)va_arg(ap, size_t); pErrorNumber = (PINT)va_arg(ap, int *); ret = _nss_lsass_getgrgid_r( gid, pResultGroup, pszBuf, stBufLen, pErrorNumber); if(pResult) { *((struct group**)pResult) = ret != NSS_STATUS_SUCCESS ? NULL : pResultGroup; } return ret; } static int LsaNSSFindGroupByName( PVOID pResult, PVOID pData, va_list ap ) { int ret = 0; PCSTR pszGroupName = NULL; struct group* pResultGroup = NULL; PSTR pszBuf = NULL; size_t stBufLen = 0; PINT pErrorNumber = NULL; pszGroupName = va_arg(ap, PCSTR); pResultGroup = (struct group*)va_arg(ap, struct group *); pszBuf = (PSTR)va_arg(ap, char*); stBufLen = (size_t)va_arg(ap, size_t); pErrorNumber = (PINT)va_arg(ap, int *); ret = _nss_lsass_getgrnam_r( pszGroupName, pResultGroup, pszBuf, stBufLen, pErrorNumber); if(pResult) { *((struct group**)pResult) = ret != NSS_STATUS_SUCCESS ? NULL : pResultGroup; } return ret; } static int LsaNSSBeginEnumGroups( PVOID pResult, PVOID pData, va_list ap ) { int ret = _nss_lsass_setgrent(); return ret; } static int LsaNSSEnumGroups( PVOID pResult, PVOID pData, va_list ap ) { int ret = 0; struct group* pResultGroup = NULL; PSTR pszBuf = NULL; size_t stBufLen = 0; PINT pErrorNumber = NULL; pResultGroup = (struct group*)va_arg(ap, struct group*); pszBuf = (PSTR)va_arg(ap, char*); stBufLen = (size_t)va_arg(ap, size_t); pErrorNumber = (PINT)va_arg(ap, int*); ret = _nss_lsass_getgrent_r( pResultGroup, pszBuf, stBufLen, pErrorNumber); if(pResult) { *((struct group**)pResult) = ret != NSS_STATUS_SUCCESS ? NULL : pResultGroup; } return ret; } static int LsaNSSEndEnumGroups( PVOID pResult, PVOID pData, va_list ap ) { int ret = _nss_lsass_endgrent(); return ret; } static int LsaNSSGetGroupMembership( PVOID pResult, PVOID pData, va_list ap ) { int ret = 0, err = 0; PCSTR pszUserName = va_arg(ap, PCSTR); gid_t groupGid = va_arg(ap, gid_t); gid_t* pResultGids = va_arg(ap, gid_t*); long int maxResultGids = (long int) va_arg(ap, int); PINT pNumResultGids = va_arg(ap, PINT); gid_t* pMyResultGids = NULL; long int myResultsSize = 0; long int myResultsCapacity = maxResultGids; ret = MAP_LSA_ERROR(&err, LwAllocateMemory( sizeof(gid_t) * maxResultGids, (PVOID*)&pMyResultGids)); BAIL_ON_NSS_ERROR(ret); ret = _nss_lsass_initgroups_dyn( pszUserName, groupGid, &myResultsSize, &myResultsCapacity, &pMyResultGids, maxResultGids, &err); BAIL_ON_NSS_ERROR(ret); memcpy(pResultGids, pMyResultGids, sizeof(gid_t) * myResultsSize); *pNumResultGids = (int) myResultsSize; cleanup: LW_SAFE_FREE_MEMORY(pMyResultGids); return ret; error: errno = err; goto cleanup; } #endif /* __LWI__FREEBSD__ */