2005-01-09 15:55:25 +03:00
/*
Unix SMB / CIFS implementation .
Anonymous Authentification
Copyright ( C ) Stefan Metzmacher 2004 - 2005
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-10 06:07:03 +04:00
the Free Software Foundation ; either version 3 of the License , or
2005-01-09 15:55:25 +03:00
( at your option ) any later version .
This program 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 General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 06:07:03 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2005-01-09 15:55:25 +03:00
*/
# include "includes.h"
# include "auth/auth.h"
2008-05-05 13:28:38 +04:00
# include "auth/ntlm/auth_proto.h"
2007-12-03 17:53:17 +03:00
# include "param/param.h"
2005-01-09 15:55:25 +03:00
2017-04-20 22:24:43 +03:00
_PUBLIC_ NTSTATUS auth4_anonymous_init ( TALLOC_CTX * ) ;
2011-03-19 02:44:28 +03:00
2005-01-09 15:55:25 +03:00
/**
* Return a anonymous logon for anonymous users ( username = " " )
*
* Typically used as the first module in the auth chain , this allows
* anonymou logons to be dealt with in one place . Non - anonymou logons ' fail '
* and pass onto the next module .
* */
2006-07-27 15:24:18 +04:00
static NTSTATUS anonymous_want_check ( struct auth_method_context * ctx ,
TALLOC_CTX * mem_ctx ,
const struct auth_usersupplied_info * user_info )
2005-01-09 15:55:25 +03:00
{
2005-07-22 08:10:07 +04:00
if ( user_info - > client . account_name & & * user_info - > client . account_name ) {
2005-01-09 15:55:25 +03:00
return NT_STATUS_NOT_IMPLEMENTED ;
}
2016-04-27 02:44:56 +03:00
switch ( user_info - > password_state ) {
case AUTH_PASSWORD_PLAIN :
if ( user_info - > password . plaintext ! = NULL & &
strlen ( user_info - > password . plaintext ) > 0 )
{
return NT_STATUS_NOT_IMPLEMENTED ;
}
break ;
case AUTH_PASSWORD_HASH :
if ( user_info - > password . hash . lanman ! = NULL ) {
return NT_STATUS_NOT_IMPLEMENTED ;
}
if ( user_info - > password . hash . nt ! = NULL ) {
return NT_STATUS_NOT_IMPLEMENTED ;
}
break ;
case AUTH_PASSWORD_RESPONSE :
if ( user_info - > password . response . lanman . length = = 1 ) {
if ( user_info - > password . response . lanman . data [ 0 ] ! = ' \0 ' ) {
return NT_STATUS_NOT_IMPLEMENTED ;
}
} else if ( user_info - > password . response . lanman . length > 1 ) {
return NT_STATUS_NOT_IMPLEMENTED ;
}
if ( user_info - > password . response . nt . length > 0 ) {
return NT_STATUS_NOT_IMPLEMENTED ;
}
break ;
}
2006-07-27 15:24:18 +04:00
return NT_STATUS_OK ;
}
/**
* Return a anonymous logon for anonymous users ( username = " " )
*
* Typically used as the first module in the auth chain , this allows
* anonymou logons to be dealt with in one place . Non - anonymou logons ' fail '
* and pass onto the next module .
* */
static NTSTATUS anonymous_check_password ( struct auth_method_context * ctx ,
TALLOC_CTX * mem_ctx ,
const struct auth_usersupplied_info * user_info ,
2017-04-03 06:21:29 +03:00
struct auth_user_info_dc * * _user_info_dc ,
bool * authoritative )
2006-07-27 15:24:18 +04:00
{
2011-02-08 08:53:13 +03:00
return auth_anonymous_user_info_dc ( mem_ctx , lpcfg_netbios_name ( ctx - > auth_ctx - > lp_ctx ) , _user_info_dc ) ;
2005-01-09 15:55:25 +03:00
}
2007-12-10 06:33:39 +03:00
static const struct auth_operations anonymous_auth_ops = {
2005-01-09 15:55:25 +03:00
. name = " anonymous " ,
2006-07-27 15:24:18 +04:00
. want_check = anonymous_want_check ,
2005-01-09 15:55:25 +03:00
. check_password = anonymous_check_password
} ;
2017-04-20 22:24:43 +03:00
_PUBLIC_ NTSTATUS auth4_anonymous_init ( TALLOC_CTX * ctx )
2005-01-09 15:55:25 +03:00
{
NTSTATUS ret ;
2017-05-09 22:39:14 +03:00
ret = auth_register ( ctx , & anonymous_auth_ops ) ;
2005-01-09 15:55:25 +03:00
if ( ! NT_STATUS_IS_OK ( ret ) ) {
DEBUG ( 0 , ( " Failed to register 'anonymous' auth backend! \n " ) ) ;
return ret ;
}
return ret ;
}