diff options
author | PKI Team <PKI Team@c9f7a03b-bd48-0410-a16d-cbbf54688b0b> | 2008-03-18 22:36:57 +0000 |
---|---|---|
committer | PKI Team <PKI Team@c9f7a03b-bd48-0410-a16d-cbbf54688b0b> | 2008-03-18 22:36:57 +0000 |
commit | d0f2e4efbd3eb0f1d7f5a28e7f97c1fb4ec027bb (patch) | |
tree | 7e7473fae8af5ad7e6cda7eabbef787093fc59a7 /pki/base/tps/src/include/authentication | |
parent | 273f8d85df5c31293a908185622b378c8f3cf7e8 (diff) | |
download | pki-d0f2e4efbd3eb0f1d7f5a28e7f97c1fb4ec027bb.tar.gz pki-d0f2e4efbd3eb0f1d7f5a28e7f97c1fb4ec027bb.tar.xz pki-d0f2e4efbd3eb0f1d7f5a28e7f97c1fb4ec027bb.zip |
Initial open source version based upon proprietary Red Hat Certificate System (RHCS) 7.3.
git-svn-id: svn+ssh://svn.fedorahosted.org/svn/pki/trunk@2 c9f7a03b-bd48-0410-a16d-cbbf54688b0b
Diffstat (limited to 'pki/base/tps/src/include/authentication')
3 files changed, 229 insertions, 0 deletions
diff --git a/pki/base/tps/src/include/authentication/AuthParams.h b/pki/base/tps/src/include/authentication/AuthParams.h new file mode 100644 index 000000000..e0d39a249 --- /dev/null +++ b/pki/base/tps/src/include/authentication/AuthParams.h @@ -0,0 +1,64 @@ +/* --- BEGIN COPYRIGHT BLOCK --- + * 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; + * version 2.1 of the License. + * + * 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 library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301 USA + * + * Copyright (C) 2007 Red Hat, Inc. + * All rights reserved. + * --- END COPYRIGHT BLOCK --- + */ + +#ifndef AUTHPARAMS_H +#define AUTHPARAMS_H + +#ifdef HAVE_CONFIG_H +#ifndef AUTOTOOLS_CONFIG_H +#define AUTOTOOLS_CONFIG_H + +/* Eliminate warnings when using Autotools */ +#undef PACKAGE_BUGREPORT +#undef PACKAGE_NAME +#undef PACKAGE_STRING +#undef PACKAGE_TARNAME +#undef PACKAGE_VERSION + +#include <config.h> +#endif /* AUTOTOOLS_CONFIG_H */ +#endif /* HAVE_CONFIG_H */ + +#include "main/NameValueSet.h" + +#ifdef XP_WIN32 +#define TPS_PUBLIC __declspec(dllexport) +#else /* !XP_WIN32 */ +#define TPS_PUBLIC +#endif /* !XP_WIN32 */ + +class AuthParams : public NameValueSet +{ + public: + TPS_PUBLIC AuthParams(); + virtual ~AuthParams(); + public: + TPS_PUBLIC void SetUID(char *uid); + TPS_PUBLIC char *GetUID(); + TPS_PUBLIC void SetPassword(char *pwd); + TPS_PUBLIC char *GetPassword(); + void SetSecuridValue(char *securidValue); + TPS_PUBLIC char *GetSecuridValue(); + void SetSecuridPin(char *securidPin); + TPS_PUBLIC char *GetSecuridPin(); +}; + +#endif /* AUTHPARAMS_H */ diff --git a/pki/base/tps/src/include/authentication/Authentication.h b/pki/base/tps/src/include/authentication/Authentication.h new file mode 100644 index 000000000..ae2b0c6fb --- /dev/null +++ b/pki/base/tps/src/include/authentication/Authentication.h @@ -0,0 +1,80 @@ +/* --- BEGIN COPYRIGHT BLOCK --- + * 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; + * version 2.1 of the License. + * + * 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 library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301 USA + * + * Copyright (C) 2007 Red Hat, Inc. + * All rights reserved. + * --- END COPYRIGHT BLOCK --- + */ + +#ifndef AUTHENTICATION_H +#define AUTHENTICATION_H + +#ifdef HAVE_CONFIG_H +#ifndef AUTOTOOLS_CONFIG_H +#define AUTOTOOLS_CONFIG_H + +/* Eliminate warnings when using Autotools */ +#undef PACKAGE_BUGREPORT +#undef PACKAGE_NAME +#undef PACKAGE_STRING +#undef PACKAGE_TARNAME +#undef PACKAGE_VERSION + +#include <config.h> +#endif /* AUTOTOOLS_CONFIG_H */ +#endif /* HAVE_CONFIG_H */ + +#include "main/Login.h" +#include "main/SecureId.h" +#include "main/RA_Session.h" +#include "authentication/AuthParams.h" + +#ifdef XP_WIN32 +#define TPS_PUBLIC __declspec(dllexport) +#else /* !XP_WIN32 */ +#define TPS_PUBLIC +#endif /* !XP_WIN32 */ + +#define TPS_AUTH_OK 0 +#define TPS_AUTH_ERROR_LDAP -1 +#define TPS_AUTH_ERROR_USERNOTFOUND -2 +#define TPS_AUTH_ERROR_PASSWORDINCORRECT -3 + + +class Authentication +{ + public: + TPS_PUBLIC Authentication(); + TPS_PUBLIC virtual ~Authentication(); + public: + virtual int Authenticate(AuthParams *params); + virtual void Initialize(int index); + public: + virtual const char *GetTitle(char *locale); + virtual const char *GetDescription(char *locale); + virtual int GetNumOfParamNames(); + virtual char *GetParamID(int index); + virtual const char *GetParamName(int index, char *locale); + virtual char *GetParamType(int index); + virtual const char *GetParamDescription(int index, char *locale); + virtual char *GetParamOption(int index); + int GetNumOfRetries(); // retries if the user entered the wrong password/securid + + protected: + int m_retries; +}; + +#endif /* AUTHENTICATION_H */ diff --git a/pki/base/tps/src/include/authentication/LDAP_Authentication.h b/pki/base/tps/src/include/authentication/LDAP_Authentication.h new file mode 100644 index 000000000..2a8c0a7d5 --- /dev/null +++ b/pki/base/tps/src/include/authentication/LDAP_Authentication.h @@ -0,0 +1,85 @@ +/* --- BEGIN COPYRIGHT BLOCK --- + * 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; + * version 2.1 of the License. + * + * 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 library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301 USA + * + * Copyright (C) 2007 Red Hat, Inc. + * All rights reserved. + * --- END COPYRIGHT BLOCK --- + */ + +#ifndef LDAP_AUTHENTICATION_H +#define LDAP_AUTHENTICATION_H + +#ifdef HAVE_CONFIG_H +#ifndef AUTOTOOLS_CONFIG_H +#define AUTOTOOLS_CONFIG_H + +/* Eliminate warnings when using Autotools */ +#undef PACKAGE_BUGREPORT +#undef PACKAGE_NAME +#undef PACKAGE_STRING +#undef PACKAGE_TARNAME +#undef PACKAGE_VERSION + +#include <config.h> +#endif /* AUTOTOOLS_CONFIG_H */ +#endif /* HAVE_CONFIG_H */ + +#include "main/Login.h" +#include "main/SecureId.h" +#include "main/RA_Session.h" +#include "authentication/Authentication.h" + +class LDAP_Authentication : public Authentication +{ + public: + LDAP_Authentication(); + ~LDAP_Authentication(); + public: + int Authenticate(AuthParams *params); + void Initialize(int index); + public: + bool IsSSL(); + char *GetHostPort(); + + public: + void GetHostPort(char **p, char **q); + virtual const char *GetTitle(char *locale); + virtual const char *GetDescription(char *locale); + virtual int GetNumOfParamNames(); + virtual char *GetParamID(int index); + virtual const char *GetParamName(int index, char *locale); + virtual char *GetParamType(int index); + virtual const char *GetParamDescription(int index, char *locale); + virtual char *GetParamOption(int index); + + private: + int m_index; + bool m_isSSL; + char *m_hostport; + char *m_attributes; + char *m_ssl; + char *m_baseDN; + char *m_bindDN; + char *m_bindPwd; + int m_connectRetries; // for failover + ConnectionInfo *m_connInfo; +}; + extern "C" + { + Authentication *GetAuthentication(); + }; + +#endif /* LDAP_AUTHENTICATION_H */ |