OW_LinuxPAMAuthenticationCL.cpp

Go to the documentation of this file.
00001 /*******************************************************************************
00002 * Copyright (C) 2001-2004 Vintela, Inc. All rights reserved.
00003 *
00004 * Redistribution and use in source and binary forms, with or without
00005 * modification, are permitted provided that the following conditions are met:
00006 *
00007 *  - Redistributions of source code must retain the above copyright notice,
00008 *    this list of conditions and the following disclaimer.
00009 *
00010 *  - Redistributions in binary form must reproduce the above copyright notice,
00011 *    this list of conditions and the following disclaimer in the documentation
00012 *    and/or other materials provided with the distribution.
00013 *
00014 *  - Neither the name of Vintela, Inc. nor the names of its
00015 *    contributors may be used to endorse or promote products derived from this
00016 *    software without specific prior written permission.
00017 *
00018 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS''
00019 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00020 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00021 * ARE DISCLAIMED. IN NO EVENT SHALL Vintela, Inc. OR THE CONTRIBUTORS
00022 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00023 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00024 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00025 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00026 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00027 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00028 * POSSIBILITY OF SUCH DAMAGE.
00029 *******************************************************************************/
00030 
00036 #include "OW_config.h"
00037 #include "OW_Exec.hpp"
00038 #include "OW_ConfigOpts.hpp"
00039 #include "OW_String.hpp"
00040 #include "OW_AuthenticatorIFC.hpp"
00041 #include "OW_Array.hpp"
00042 #if defined(OW_HAVE_SYS_WAIT_H) && defined(OW_WIFEXITED_NEEDS_WAIT_H)
00043 #include <sys/wait.h>
00044 #endif
00045 
00046 #include <string.h>
00047 
00048 namespace OW_NAMESPACE
00049 {
00050 
00051 class LinuxPAMAuthenticationCL : public AuthenticatorIFC
00052 {
00066 private:
00067    virtual bool doAuthenticate(String &userName, const String &info, String &details, OperationContext& context);
00068    
00069    virtual void doInit(ServiceEnvironmentIFCRef env);
00070    String m_allowedUsers;
00071    String m_libexecdir;
00072 };
00074 bool
00075 LinuxPAMAuthenticationCL::doAuthenticate(String &userName,
00076    const String &info, String &details, OperationContext& context)
00077 {
00078    if (info.empty())
00079    {
00080       details = "You must authenticate to access this resource";
00081       return false;
00082    }
00083    Array<String> allowedUsers = m_allowedUsers.tokenize();
00084    bool nameFound = false;
00085    for (size_t i = 0; i < allowedUsers.size(); i++)
00086    {
00087       if (allowedUsers[i].equals(userName))
00088       {
00089          nameFound = true;
00090          break;
00091       }
00092    }
00093    if (!nameFound)
00094    {
00095       return false;
00096    }
00097    String pathToPamAuth = m_libexecdir + "/PAMAuth";
00098    Array<String> commandLine;
00099    commandLine.push_back(pathToPamAuth);
00100    String output;
00101    int status = -1;
00102    int timeoutSecs = 60;
00103    int outputLimit = 1024;
00104    String input = userName + " " + info + "\n";
00105    try
00106    {
00107       Exec::executeProcessAndGatherOutput(commandLine, output, status, timeoutSecs, outputLimit, input);
00108    }
00109    catch (Exception& e)
00110    {
00111       return false;
00112    }
00113 
00114    if (WIFEXITED(status) && WEXITSTATUS(status) == 0)
00115    {
00116       return true;
00117    }
00118    return false;
00119 }
00120 void
00121 LinuxPAMAuthenticationCL::doInit(ServiceEnvironmentIFCRef env)
00122 {
00123    m_allowedUsers = env->getConfigItem(ConfigOpts::PAM_ALLOWED_USERS_opt);
00124    m_libexecdir = env->getConfigItem(ConfigOpts::LIBEXECDIR_opt, OW_DEFAULT_OWLIBEXECDIR);
00125 }
00126 
00127 } // end namespace OW_NAMESPACE
00128 
00130 OW_AUTHENTICATOR_FACTORY(OpenWBEM::LinuxPAMAuthenticationCL,pamcl);
00131 

Generated on Thu Feb 9 08:48:01 2006 for openwbem by  doxygen 1.4.6