ffa6aa7ecd
Monotone-Parent: 2d120d90819b42e21a50956a14c0c5d130cfdf09 Monotone-Revision: 376221b991f7b0bee18cfede79614398e85e5b99 Monotone-Author: wsourdeau@inverse.ca Monotone-Date: 2006-10-31T18:52:52 Monotone-Branch: ca.inverse.sogo
127 lines
2.8 KiB
Objective-C
127 lines
2.8 KiB
Objective-C
/*
|
|
Copyright (C) 2004 SKYRIX Software AG
|
|
|
|
This file is part of OpenGroupware.org.
|
|
|
|
OGo 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, or (at your option) any
|
|
later version.
|
|
|
|
OGo 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 OGo; see the file COPYING. If not, write to the
|
|
Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
|
|
02111-1307, USA.
|
|
*/
|
|
|
|
#import <NGLdap/NGLdapConnection.h>
|
|
|
|
#include "SOGoAuthenticator.h"
|
|
#include "SOGoUser.h"
|
|
#include "common.h"
|
|
|
|
@implementation SOGoAuthenticator
|
|
|
|
static SOGoAuthenticator *auth = nil;
|
|
|
|
+ (id) sharedSOGoAuthenticator
|
|
{
|
|
if (auth == nil)
|
|
auth = [[self alloc] init];
|
|
return auth;
|
|
}
|
|
|
|
- (id) init
|
|
{
|
|
if ((self = [super init]))
|
|
{
|
|
ud = [NSUserDefaults standardUserDefaults];
|
|
|
|
LDAPBaseDN = nil;
|
|
LDAPHost = nil;
|
|
LDAPPort = -1;
|
|
|
|
authMethod = [[ud stringForKey:@"AuthentificationMethod"] retain];
|
|
if ([authMethod isEqualToString: @"LDAP"])
|
|
{
|
|
LDAPBaseDN = [[ud stringForKey:@"LDAPRootDN"] retain];
|
|
LDAPHost = [[ud stringForKey:@"LDAPHost"] retain];
|
|
LDAPPort = [ud integerForKey:@"LDAPPort"];
|
|
}
|
|
}
|
|
|
|
return self;
|
|
}
|
|
|
|
- (void) dealloc
|
|
{
|
|
if (LDAPBaseDN)
|
|
[LDAPBaseDN release];
|
|
if (LDAPHost)
|
|
[LDAPHost release];
|
|
[authMethod release];
|
|
[super dealloc];
|
|
}
|
|
|
|
- (BOOL) checkLogin: (NSString *) _login
|
|
password: (NSString *) _pwd
|
|
{
|
|
BOOL result;
|
|
|
|
if ([authMethod isEqualToString: @"LDAP"])
|
|
result = [self LDAPCheckLogin: _login password: _pwd];
|
|
else
|
|
{
|
|
if ([_login length] == 0)
|
|
result = NO;
|
|
else
|
|
result = YES;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
- (BOOL) LDAPCheckLogin: (NSString *) _login
|
|
password: (NSString *) _pwd
|
|
{
|
|
return [NGLdapConnection checkPassword: _pwd
|
|
ofLogin: _login
|
|
atBaseDN: LDAPBaseDN
|
|
onHost: LDAPHost
|
|
port: LDAPPort];
|
|
}
|
|
|
|
/* create SOGoUser */
|
|
|
|
- (SoUser *)userInContext:(WOContext *)_ctx
|
|
{
|
|
static SoUser *anonymous = nil;
|
|
NSString *login;
|
|
NSArray *uroles;
|
|
|
|
if (!anonymous)
|
|
anonymous
|
|
= [[SOGoUser alloc] initWithLogin:@"anonymous"
|
|
roles: [NSArray arrayWithObject: SoRole_Anonymous]];
|
|
|
|
if ((login = [self checkCredentialsInContext:_ctx]) == nil)
|
|
/* some error (otherwise result would have been anonymous */
|
|
return nil;
|
|
|
|
if ([login isEqualToString:@"anonymous"])
|
|
return anonymous;
|
|
|
|
uroles = [self rolesForLogin:login];
|
|
|
|
return [[[SOGoUser alloc] initWithLogin:login
|
|
roles:uroles]
|
|
autorelease];
|
|
}
|
|
|
|
@end /* SOGoAuthenticator */
|