sogo/SoObjects/SOGo/SOGoAuthenticator.m
Wolfgang Sourdeau 98b2014f6b Monotone-Parent: 866444d29ef56047291b49a17e79ceacf8d03e2b
Monotone-Revision: 05c004606ea7630c74dd1bb97957bc57215c5e55

Monotone-Author: wsourdeau@inverse.ca
Monotone-Date: 2007-05-09T19:21:01
Monotone-Branch: ca.inverse.sogo
2007-05-09 19:21:01 +00:00

168 lines
4.2 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>
#import "SOGoPermissions.h"
#import "LDAPUserManager.h"
#import "SOGoAuthenticator.h"
#import "SOGoUser.h"
#import "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 accept;
if ([authMethod isEqualToString: @"LDAP"])
accept = [self LDAPCheckLogin: _login password: _pwd];
else
accept = ([_login length] > 0);
return (([_login isEqualToString: @"freebusy"]
&& [_pwd isEqualToString: @"freebusy"])
|| accept);
}
- (BOOL) LDAPCheckLogin: (NSString *) _login
password: (NSString *) _pwd
{
LDAPUserManager *um;
um = [LDAPUserManager sharedUserManager];
return [um checkLogin: _login andPassword: _pwd];
}
/* create SOGoUser */
- (SOGoUser *) userInContext: (WOContext *)_ctx
{
static SOGoUser *anonymous = nil, *freebusy;
SOGoUser *user;
NSArray *traversalPath;
NSString *login;
if (!anonymous)
anonymous
= [[SOGoUser alloc] initWithLogin: @"anonymous"
roles: [NSArray arrayWithObject: SoRole_Anonymous]];
if (!freebusy)
freebusy
= [[SOGoUser alloc] initWithLogin: @"freebusy"
roles: [NSArray arrayWithObject: SOGoRole_FreeBusy]];
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
user = [SOGoUser userWithLogin: login
roles: [self rolesForLogin: login]];
}
else
user = nil;
return user;
}
// - (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;
// }
@end /* SOGoAuthenticator */