2006-06-15 21:34:10 +02:00
|
|
|
/*
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2006-07-07 18:04:46 +02:00
|
|
|
#import <NGLdap/NGLdapConnection.h>
|
2006-12-14 22:20:13 +01:00
|
|
|
#import "SOGoPermissions.h"
|
2006-07-07 18:04:46 +02:00
|
|
|
|
2007-05-09 21:21:01 +02:00
|
|
|
#import "LDAPUserManager.h"
|
|
|
|
|
|
|
|
#import "SOGoAuthenticator.h"
|
|
|
|
#import "SOGoUser.h"
|
|
|
|
#import "common.h"
|
2006-06-15 21:34:10 +02:00
|
|
|
|
|
|
|
@implementation SOGoAuthenticator
|
|
|
|
|
2006-07-07 18:04:46 +02:00
|
|
|
static SOGoAuthenticator *auth = nil;
|
2006-06-15 21:34:10 +02:00
|
|
|
|
2006-07-07 18:04:46 +02:00
|
|
|
+ (id) sharedSOGoAuthenticator
|
|
|
|
{
|
2006-06-15 21:34:10 +02:00
|
|
|
if (auth == nil)
|
|
|
|
auth = [[self alloc] init];
|
|
|
|
return auth;
|
|
|
|
}
|
|
|
|
|
2006-07-07 18:04:46 +02:00
|
|
|
- (id) init
|
|
|
|
{
|
|
|
|
if ((self = [super init]))
|
|
|
|
{
|
|
|
|
ud = [NSUserDefaults standardUserDefaults];
|
2006-06-15 21:34:10 +02:00
|
|
|
|
2006-07-07 18:04:46 +02:00
|
|
|
LDAPBaseDN = nil;
|
|
|
|
LDAPHost = nil;
|
|
|
|
LDAPPort = -1;
|
|
|
|
|
|
|
|
authMethod = [[ud stringForKey:@"AuthentificationMethod"] retain];
|
|
|
|
if ([authMethod isEqualToString: @"LDAP"])
|
|
|
|
{
|
2007-05-09 21:21:01 +02:00
|
|
|
// LDAPBaseDN = [[ud stringForKey:@"LDAPRootDN"] retain];
|
|
|
|
// LDAPHost = [[ud stringForKey:@"LDAPHost"] retain];
|
|
|
|
// LDAPPort = [ud integerForKey:@"LDAPPort"];
|
2006-07-07 18:04:46 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) dealloc
|
|
|
|
{
|
|
|
|
if (LDAPBaseDN)
|
|
|
|
[LDAPBaseDN release];
|
|
|
|
if (LDAPHost)
|
|
|
|
[LDAPHost release];
|
|
|
|
[authMethod release];
|
|
|
|
[super dealloc];
|
|
|
|
}
|
|
|
|
|
|
|
|
- (BOOL) checkLogin: (NSString *) _login
|
|
|
|
password: (NSString *) _pwd
|
|
|
|
{
|
2007-02-05 23:03:01 +01:00
|
|
|
BOOL accept;
|
|
|
|
|
|
|
|
if ([authMethod isEqualToString: @"LDAP"])
|
|
|
|
accept = [self LDAPCheckLogin: _login password: _pwd];
|
|
|
|
else
|
|
|
|
accept = ([_login length] > 0);
|
|
|
|
|
2007-01-13 00:22:04 +01:00
|
|
|
return (([_login isEqualToString: @"freebusy"]
|
|
|
|
&& [_pwd isEqualToString: @"freebusy"])
|
2007-02-05 23:03:01 +01:00
|
|
|
|| accept);
|
2006-07-07 18:04:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (BOOL) LDAPCheckLogin: (NSString *) _login
|
|
|
|
password: (NSString *) _pwd
|
|
|
|
{
|
2007-05-09 21:21:01 +02:00
|
|
|
LDAPUserManager *um;
|
|
|
|
|
|
|
|
um = [LDAPUserManager sharedUserManager];
|
|
|
|
|
|
|
|
return [um checkLogin: _login andPassword: _pwd];
|
2006-06-15 21:34:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* create SOGoUser */
|
|
|
|
|
2007-03-07 23:31:02 +01:00
|
|
|
- (SOGoUser *) userInContext: (WOContext *)_ctx
|
2006-07-07 18:04:46 +02:00
|
|
|
{
|
2007-03-07 23:31:02 +01:00
|
|
|
static SOGoUser *anonymous = nil, *freebusy;
|
2007-03-18 16:22:05 +01:00
|
|
|
SOGoUser *user;
|
2007-01-26 23:25:23 +01:00
|
|
|
NSArray *traversalPath;
|
|
|
|
NSString *login;
|
|
|
|
|
2006-07-07 18:04:46 +02:00
|
|
|
if (!anonymous)
|
|
|
|
anonymous
|
2007-05-09 21:21:01 +02:00
|
|
|
= [[SOGoUser alloc] initWithLogin: @"anonymous"
|
2006-07-07 18:04:46 +02:00
|
|
|
roles: [NSArray arrayWithObject: SoRole_Anonymous]];
|
2006-12-14 22:20:13 +01:00
|
|
|
if (!freebusy)
|
|
|
|
freebusy
|
|
|
|
= [[SOGoUser alloc] initWithLogin: @"freebusy"
|
|
|
|
roles: [NSArray arrayWithObject: SOGoRole_FreeBusy]];
|
|
|
|
|
2007-01-26 23:25:23 +01:00
|
|
|
login = [self checkCredentialsInContext:_ctx];
|
|
|
|
if (login)
|
|
|
|
{
|
|
|
|
if ([login isEqualToString: @"anonymous"])
|
|
|
|
{
|
|
|
|
traversalPath = [_ctx objectForKey: @"SoRequestTraversalPath"];
|
|
|
|
if ([[traversalPath lastObject] isEqualToString: @"freebusy.ifb"])
|
|
|
|
user = freebusy;
|
|
|
|
else
|
|
|
|
user = anonymous;
|
|
|
|
}
|
|
|
|
else
|
2007-05-09 21:21:01 +02:00
|
|
|
user = [SOGoUser userWithLogin: login
|
|
|
|
roles: [self rolesForLogin: login]];
|
2007-01-26 23:25:23 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
user = nil;
|
2006-07-07 18:04:46 +02:00
|
|
|
|
2007-01-26 23:25:23 +01:00
|
|
|
return user;
|
2006-06-15 21:34:10 +02:00
|
|
|
}
|
|
|
|
|
2006-12-14 22:20:13 +01:00
|
|
|
// - (BOOL) renderException: (NSException *) exception
|
|
|
|
// inContext: (WOContext *) context
|
|
|
|
// {
|
|
|
|
// id renderedException;
|
|
|
|
// WOComponent *tmpComponent;
|
|
|
|
// WOResponse *response;
|
|
|
|
// BOOL rc;
|
|
|
|
|
|
|
|
// rc = [super renderException: exception inContext: context];
|
|
|
|
// if (!rc)
|
|
|
|
// {
|
|
|
|
// tmpComponent = [WOComponent new];
|
|
|
|
// renderedException = [tmpComponent pageWithName: @"UIxException"];
|
|
|
|
// if (renderedException)
|
|
|
|
// {
|
|
|
|
// rc = YES;
|
|
|
|
// response = [context response];
|
|
|
|
// [response setHeader: @"text/html" forKey: @"content-type"];
|
|
|
|
// [renderedException setClientObject: exception];
|
|
|
|
// [context setPage: renderedException];
|
|
|
|
// [renderedException appendToResponse: response
|
|
|
|
// inContext: context];
|
|
|
|
// }
|
|
|
|
// [tmpComponent release];
|
|
|
|
// }
|
|
|
|
|
|
|
|
// return rc;
|
|
|
|
// }
|
|
|
|
|
2006-06-15 21:34:10 +02:00
|
|
|
@end /* SOGoAuthenticator */
|