CASA/CASA-auth-token/non-java/client
Juan Carlos Luciani 01b99ffc0d Making changes to remove the need for the auth.policy to contain
the mechanism information element. This change breaks the build since it
is not complete.
2006-11-03 13:35:36 +00:00
..
csharp Support for DLU by allowing luid's to be passed by the system process. 2006-10-17 20:39:48 +00:00
linux Made modifications to switch the client to communicate with ATSs over SSL. Still need to make changes to the linux rpc.c to have all of the necessary changes completed. 2006-11-02 03:49:16 +00:00
mechanisms Making changes to remove the need for the auth.policy to contain 2006-11-03 13:35:36 +00:00
test Made MSDN project file updates to refer to the include folders using relative paths. 2006-10-03 15:28:54 +00:00
windows Made changes necessary to build the client on windows using cygwin. 2006-11-02 04:35:33 +00:00
authmech.c Made modifications to switch the client to communicate with ATSs over SSL. Still need to make changes to the linux rpc.c to have all of the necessary changes completed. 2006-11-02 03:49:16 +00:00
authmsg.c Fixed all of the compiler warnings for the client components. 2006-10-06 20:13:14 +00:00
authpolicy.c Making changes to remove the need for the auth.policy to contain 2006-11-03 13:35:36 +00:00
cache.c Added the capability to scope credential store access. This is only allowed by miCASA if the current user is running in the context of system. This is useful to system type applications doing work on behalf of other users. 2006-10-17 17:55:09 +00:00
client.conf Made modifications to switch the client to communicate with ATSs over SSL. Still need to make changes to the linux rpc.c to have all of the necessary changes completed. 2006-11-02 03:49:16 +00:00
config_if.h Adding client files lost during folder re-structuring. 2006-08-07 19:12:49 +00:00
config.c Made some formatting changes, added some additional debug statements, and updated the project file to adjust for the new directory structure. 2006-08-14 20:13:53 +00:00
engine.c Made modifications to switch the client to communicate with ATSs over SSL. Still need to make changes to the linux rpc.c to have all of the necessary changes completed. 2006-11-02 03:49:16 +00:00
getpolicymsg.c Fixed all of the compiler warnings for the client components. 2006-10-06 20:13:14 +00:00
gettokenmsg.c Fixed all of the compiler warnings for the client components. 2006-10-06 20:13:14 +00:00
internal.h Made modifications to switch the client to communicate with ATSs over SSL. Still need to make changes to the linux rpc.c to have all of the necessary changes completed. 2006-11-02 03:49:16 +00:00
invalidcert.c Made modifications to switch the client to communicate with ATSs over SSL. Still need to make changes to the linux rpc.c to have all of the necessary changes completed. 2006-11-02 03:49:16 +00:00
Makefile.am Made changes necessary to build the client on windows using cygwin. 2006-11-02 04:35:33 +00:00
mech_if.h Made modifications to switch the client to communicate with ATSs over SSL. Still need to make changes to the linux rpc.c to have all of the necessary changes completed. 2006-11-02 03:49:16 +00:00
README Created client-devel RPM and made changes to deal with changes made to 2006-10-19 15:23:23 +00:00
TODO Brought up to date the README and TODO files. 2006-10-10 14:47:19 +00:00
util.c Adding client files lost during folder re-structuring. 2006-08-07 19:12:49 +00:00

/***********************************************************************
 * 
 *  Copyright (C) 2006 Novell, Inc. 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; 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
 *  Library 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, Novell, Inc.
 * 
 *  To contact Novell about this file by physical or electronic mail, 
 *  you may find current contact information at www.novell.com.
 * 
 *  Author: Juan Carlos Luciani <jluciani@novell.com>
 *
 ***********************************************************************/
/***********************************************************************
 *
 *  README for libcasa_c_authtoken
 *
 ***********************************************************************/

INTRODUCTION

libcasa_c_authtoken is the client auth_token engine. It is responsible for
interacting with ATSs, invoking the authentication mechanism plug-ins, and
managing the authentication token cache. libcasa_c_authtoken also provides
the Get Authentication Token API.

CONFIGURING ADDITIONAL AUTHENTICATION MECHANISM MODULES

libcasa_c_authtoken utilizes mechanism plug-ins for authenticating to ATSs.
The client auth_token package installs mechanisms for the support of Kerberos5
and Username/Password authentication. To configure additional authentication mechanism
plug-ins, place their configuration file in the folder for CASA Authentication Token module
configuration. The path to this folder under linux is /etc/CASA/authtoken/client/mechanisms/.
The path to this folder under Windows is \Program Files\novell\CASA\Etc\Auth\Mechanisms\. The name of
the plug-in configuration file is related to the authentication mechanism type in the following
manner: AuthenticationMechanismTypeName.conf.

Authentication Mechanism plug-in configuration files must must contain a directive indicating the
path to the library implementing the Authentication Mechanism (See the configuration file
for the Kr5Authenticate plug-in for an example).

CLIENT APPLICATION PROGRAMMING NOTES

The Get CASA Authentication Token API is defined in casa_c_authtoken.h.

The API consists of a call to obtain authentication tokens. The caller must supply the name of the
service to which it wants to authenticate along with the name of the host where it resides. The
returned authentication token is a Base64 encoded string.

Applications utilizing CASA Authentication Tokens as passwords in protocols that require the
transfer of user name and password credentials should verify or remove any password length limits
as the length of CASA Authentication Tokens may be over 1K bytes. The size of the CASA Authentication
Tokens is directly dependent on the amount of identity information configured as required by the
consuming service. These applications should also set the user name to "CasaPrincipal".

For examples of code which uses the Get CASA Authentication Token API look at the test application
under the test folder.

AUTHENTICATION MECHANISM PROGRAMMING NOTES

The Authentication Mechanism API is defined in mech_if.h.

For example implementations see the code for the krb5 and the pwd mechanisms.

SECURITY CONSIDERATIONS

CASA Authentication Tokens when compromised can be used to either impersonate
a user or to obtain identity information about the user. Because of this it is
important that the tokens be secured by applications making use of them. It is
recommended that the tokens be transmitted using SSL.