2010-10-01 22:35:29 +02:00
|
|
|
/* MAPIStoreContext.m - this file is part of SOGo
|
2010-10-01 20:54:30 +02:00
|
|
|
*
|
2010-10-01 22:35:29 +02:00
|
|
|
* Copyright (C) 2010 Inverse inc.
|
2010-10-01 20:54:30 +02:00
|
|
|
*
|
|
|
|
* Author: Wolfgang Sourdeau <wsourdeau@inverse.ca>
|
|
|
|
*
|
|
|
|
* This file is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
* any later version.
|
|
|
|
*
|
|
|
|
* This file 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
|
|
|
|
* along with this program; see the file COPYING. If not, write to
|
|
|
|
* the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#import <Foundation/NSCalendarDate.h>
|
|
|
|
#import <Foundation/NSDictionary.h>
|
|
|
|
#import <Foundation/NSEnumerator.h>
|
|
|
|
#import <Foundation/NSNull.h>
|
|
|
|
#import <Foundation/NSURL.h>
|
|
|
|
#import <Foundation/NSThread.h>
|
|
|
|
#import <Foundation/NSTimeZone.h>
|
|
|
|
#import <Foundation/NSValue.h>
|
|
|
|
|
|
|
|
#import <NGObjWeb/WOContext.h>
|
|
|
|
#import <NGObjWeb/WOContext+SoObjects.h>
|
|
|
|
|
|
|
|
#import <NGExtensions/NSString+misc.h>
|
|
|
|
#import <NGExtensions/NSObject+Logs.h>
|
|
|
|
|
|
|
|
#import <SOGo/NSString+Utilities.h>
|
|
|
|
#import <SOGo/SOGoFolder.h>
|
|
|
|
#import <Mailer/SOGoMailAccount.h>
|
|
|
|
#import <Mailer/SOGoMailFolder.h>
|
|
|
|
|
|
|
|
#import "MAPIApplication.h"
|
|
|
|
#import "MAPIStoreAuthenticator.h"
|
|
|
|
#import "MAPIStoreMapping.h"
|
|
|
|
|
|
|
|
#import "MAPIStoreContext.h"
|
|
|
|
|
|
|
|
#import "NSString+MAPIStore.h"
|
|
|
|
|
|
|
|
#undef DEBUG
|
|
|
|
#include <mapistore/mapistore.h>
|
|
|
|
#include <mapistore/mapistore_errors.h>
|
|
|
|
// #include <dlinklist.h>
|
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
// NSNullK = NSClassFromString (@"NSNull");
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
// SOGoMailAccountsK = NSClassFromString (@"SOGoMailAccounts");
|
|
|
|
// SOGoMailAccountK = NSClassFromString (@"SOGoMailAccount");
|
|
|
|
// SOGoMailFolderK = NSClassFromString (@"SOGoMailFolder");
|
|
|
|
// SOGoUserFolderK = NSClassFromString (@"SOGoUserFolder");
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-06 16:27:09 +02:00
|
|
|
uint8_t *
|
|
|
|
MAPIBoolValue (void *memCtx, BOOL value)
|
|
|
|
{
|
|
|
|
uint8_t *boolValue;
|
|
|
|
|
|
|
|
boolValue = talloc_zero (memCtx, uint8_t);
|
|
|
|
*boolValue = value;
|
|
|
|
|
|
|
|
return boolValue;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t *
|
|
|
|
MAPILongValue (void *memCtx, uint32_t value)
|
|
|
|
{
|
|
|
|
uint32_t *longValue;
|
|
|
|
|
|
|
|
longValue = talloc_zero (memCtx, uint32_t);
|
|
|
|
*longValue = value;
|
|
|
|
|
|
|
|
return longValue;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint64_t *
|
|
|
|
MAPILongLongValue (void *memCtx, uint64_t value)
|
|
|
|
{
|
|
|
|
uint64_t *llongValue;
|
|
|
|
|
|
|
|
llongValue = talloc_zero (memCtx, uint64_t);
|
|
|
|
*llongValue = value;
|
|
|
|
|
|
|
|
return llongValue;
|
|
|
|
}
|
|
|
|
|
2010-10-01 20:54:30 +02:00
|
|
|
static Class SOGoObjectK, SOGoMailAccountK, SOGoMailFolderK;
|
|
|
|
|
|
|
|
@interface SOGoFolder (MAPIStoreProtocol)
|
|
|
|
|
|
|
|
- (BOOL) create;
|
|
|
|
- (NSException *) delete;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
@interface SOGoObject (MAPIStoreProtocol)
|
|
|
|
|
|
|
|
- (NSString *) davContentLength;
|
|
|
|
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation MAPIStoreContext : NSObject
|
|
|
|
|
|
|
|
/* sogo://username:password@{contacts,calendar,tasks,journal,notes,mail}/dossier/id */
|
|
|
|
|
|
|
|
static MAPIStoreMapping *mapping = nil;
|
|
|
|
|
|
|
|
+ (void) initialize
|
|
|
|
{
|
|
|
|
SOGoObjectK = [SOGoObject class];
|
2010-10-01 22:35:29 +02:00
|
|
|
SOGoMailAccountK = NSClassFromString (@"SOGoMailAccount");
|
|
|
|
SOGoMailFolderK = NSClassFromString (@"SOGoMailFolder");
|
2010-10-01 20:54:30 +02:00
|
|
|
mapping = [MAPIStoreMapping new];
|
|
|
|
}
|
|
|
|
|
|
|
|
+ (id) contextFromURI: (const char *) newUri
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
MAPIStoreContext *context;
|
|
|
|
MAPIStoreAuthenticator *authenticator;
|
|
|
|
NSString *contextClass, *module, *completeURLString, *urlString;
|
|
|
|
NSURL *baseURL;
|
|
|
|
|
|
|
|
NSLog (@"METHOD '%s' (%d) -- uri: '%s'", __FUNCTION__, __LINE__, newUri);
|
|
|
|
|
|
|
|
context = nil;
|
|
|
|
|
|
|
|
urlString = [NSString stringWithUTF8String: newUri];
|
|
|
|
if (urlString)
|
|
|
|
{
|
|
|
|
completeURLString = [@"sogo://" stringByAppendingString: urlString];
|
|
|
|
baseURL = [NSURL URLWithString: completeURLString];
|
|
|
|
if (baseURL)
|
|
|
|
{
|
|
|
|
module = [baseURL host];
|
|
|
|
if (module)
|
|
|
|
{
|
|
|
|
if ([module isEqualToString: @"mail"])
|
|
|
|
contextClass = @"MAPIStoreMailContext";
|
|
|
|
else if ([module isEqualToString: @"contacts"])
|
|
|
|
contextClass = @"MAPIStoreContactsContext";
|
|
|
|
else if ([module isEqualToString: @"calendar"])
|
|
|
|
contextClass = @"MAPIStoreCalendarContext";
|
2010-10-01 23:31:58 +02:00
|
|
|
else if ([module isEqualToString: @"tasks"])
|
|
|
|
contextClass = @"MAPIStoreTasksContext";
|
2010-10-01 22:35:29 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
NSLog (@"ERROR: unrecognized module name '%@'", module);
|
|
|
|
contextClass = nil;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
if (contextClass)
|
|
|
|
{
|
|
|
|
[mapping registerURL: completeURLString];
|
|
|
|
context = [NSClassFromString (contextClass) new];
|
|
|
|
[context autorelease];
|
|
|
|
|
|
|
|
authenticator = [MAPIStoreAuthenticator new];
|
|
|
|
[authenticator setUsername: [baseURL user]];
|
|
|
|
[authenticator setPassword: [baseURL password]];
|
|
|
|
[context setAuthenticator: authenticator];
|
|
|
|
[authenticator release];
|
|
|
|
|
|
|
|
[context setupRequest];
|
|
|
|
[context setupModuleFolder];
|
|
|
|
[context tearDownRequest];
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
else
|
|
|
|
NSLog (@"ERROR: url could not be parsed");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
NSLog (@"ERROR: url is an invalid UTF-8 string");
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return context;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (id) init
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
if ((self = [super init]))
|
|
|
|
{
|
|
|
|
messageCache = [NSMutableDictionary new];
|
|
|
|
subfolderCache = [NSMutableDictionary new];
|
|
|
|
woContext = [WOContext contextWithRequest: nil];
|
|
|
|
[woContext retain];
|
|
|
|
moduleFolder = nil;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"-init"];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return self;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void) dealloc
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"-dealloc"];
|
|
|
|
|
|
|
|
[messageCache release];
|
|
|
|
[subfolderCache release];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
[moduleFolder release];
|
|
|
|
[woContext release];
|
|
|
|
[authenticator release];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
[super dealloc];
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void) setAuthenticator: (MAPIStoreAuthenticator *) newAuthenticator
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
ASSIGN (authenticator, newAuthenticator);
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (MAPIStoreAuthenticator *) authenticator
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
return authenticator;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void) setMemCtx: (void *) newMemCtx
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
memCtx = newMemCtx;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void) setupRequest
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSMutableDictionary *info;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
[MAPIApp setMAPIStoreContext: self];
|
|
|
|
info = [[NSThread currentThread] threadDictionary];
|
|
|
|
[info setObject: woContext forKey:@"WOContext"];
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void) tearDownRequest
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSMutableDictionary *info;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
info = [[NSThread currentThread] threadDictionary];
|
|
|
|
[info removeObjectForKey:@"WOContext"];
|
|
|
|
[MAPIApp setMAPIStoreContext: nil];
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void) setupModuleFolder
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self subclassResponsibility: _cmd];
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
// - (void) _setNewLastObject: (id) newLastObject
|
|
|
|
// {
|
|
|
|
// id currentObject, container;
|
|
|
|
|
|
|
|
// if (newLastObject != lastObject)
|
|
|
|
// {
|
|
|
|
// currentObject = lastObject;
|
|
|
|
// while (currentObject)
|
|
|
|
// {
|
|
|
|
// container = [currentObject container];
|
|
|
|
// [currentObject release];
|
|
|
|
// currentObject = container;
|
|
|
|
// }
|
|
|
|
|
|
|
|
// currentObject = newLastObject;
|
|
|
|
// while (currentObject)
|
|
|
|
// {
|
|
|
|
// [currentObject retain];
|
|
|
|
// currentObject = [currentObject container];
|
|
|
|
// }
|
|
|
|
|
|
|
|
// lastObject = newLastObject;
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
|
2010-10-01 20:54:30 +02:00
|
|
|
- (id) lookupObject: (NSString *) objectURLString
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
id object;
|
|
|
|
NSURL *objectURL;
|
|
|
|
NSArray *path;
|
|
|
|
int count, max;
|
|
|
|
NSString *pathString, *nameInContainer;
|
|
|
|
|
|
|
|
objectURL = [NSURL URLWithString: objectURLString];
|
2010-10-01 23:24:15 +02:00
|
|
|
if (objectURL)
|
2010-10-01 22:35:29 +02:00
|
|
|
{
|
2010-10-01 23:24:15 +02:00
|
|
|
object = moduleFolder;
|
|
|
|
|
|
|
|
pathString = [objectURL path];
|
|
|
|
if ([pathString hasPrefix: @"/"])
|
|
|
|
pathString = [pathString substringFromIndex: 1];
|
|
|
|
if ([pathString length] > 0)
|
2010-10-01 22:35:29 +02:00
|
|
|
{
|
2010-10-01 23:24:15 +02:00
|
|
|
path = [pathString componentsSeparatedByString: @"/"];
|
|
|
|
max = [path count];
|
|
|
|
if (max > 0)
|
2010-10-01 22:35:29 +02:00
|
|
|
{
|
2010-10-01 23:24:15 +02:00
|
|
|
for (count = 0;
|
|
|
|
object && count < max;
|
|
|
|
count++)
|
|
|
|
{
|
|
|
|
nameInContainer = [[path objectAtIndex: count]
|
2010-10-01 22:35:29 +02:00
|
|
|
stringByUnescapingURL];
|
2010-10-01 23:24:15 +02:00
|
|
|
object = [object lookupName: nameInContainer
|
|
|
|
inContext: woContext
|
|
|
|
acquire: NO];
|
|
|
|
if ([object isKindOfClass: SOGoObjectK])
|
|
|
|
[woContext setClientObject: object];
|
|
|
|
else
|
|
|
|
object = nil;
|
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
}
|
|
|
|
}
|
2010-10-01 23:24:15 +02:00
|
|
|
else
|
|
|
|
object = nil;
|
2010-10-01 22:35:29 +02:00
|
|
|
|
|
|
|
// [self _setNewLastObject: object];
|
|
|
|
// ASSIGN (lastObjectURL, objectURLString);
|
2010-10-01 23:24:15 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
object = nil;
|
|
|
|
[self errorWithFormat: @"url string gave nil NSURL: '%@'", objectURLString];
|
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
|
|
|
|
[woContext setClientObject: object];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return object;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (NSString *) _createFolder: (struct SRow *) aRow
|
|
|
|
inParentURL: (NSString *) parentFolderURL
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSString *newFolderURL;
|
|
|
|
NSString *folderName, *nameInContainer;
|
|
|
|
SOGoFolder *parentFolder, *newFolder;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
newFolderURL = nil;
|
|
|
|
|
|
|
|
folderName = nil;
|
|
|
|
for (i = 0; !folderName && i < aRow->cValues; i++)
|
|
|
|
{
|
|
|
|
if (aRow->lpProps[i].ulPropTag == PR_DISPLAY_NAME_UNICODE)
|
|
|
|
folderName = [NSString stringWithUTF8String: aRow->lpProps[i].value.lpszW];
|
|
|
|
else if (aRow->lpProps[i].ulPropTag == PR_DISPLAY_NAME)
|
|
|
|
folderName = [NSString stringWithUTF8String: aRow->lpProps[i].value.lpszA];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (folderName)
|
|
|
|
{
|
|
|
|
parentFolder = [self lookupObject: parentFolderURL];
|
|
|
|
if (parentFolder)
|
|
|
|
{
|
|
|
|
if ([parentFolder isKindOfClass: SOGoMailAccountK]
|
|
|
|
|| [parentFolder isKindOfClass: SOGoMailFolderK])
|
|
|
|
{
|
|
|
|
nameInContainer = [NSString stringWithFormat: @"folder%@",
|
|
|
|
[folderName asCSSIdentifier]];
|
|
|
|
newFolder = [SOGoMailFolderK objectWithName: nameInContainer
|
|
|
|
inContainer: parentFolder];
|
|
|
|
if ([newFolder create])
|
|
|
|
newFolderURL = [NSString stringWithFormat: @"%@/%@",
|
|
|
|
parentFolderURL,
|
|
|
|
[nameInContainer stringByEscapingURL]];
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return newFolderURL;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
\details Create a folder in the sogo backend
|
|
|
|
|
|
|
|
\param private_data pointer to the current sogo context
|
|
|
|
|
|
|
|
\return MAPISTORE_SUCCESS on success, otherwise MAPISTORE_ERROR
|
2010-10-01 22:35:29 +02:00
|
|
|
*/
|
2010-10-01 20:54:30 +02:00
|
|
|
|
|
|
|
- (int) mkDir: (struct SRow *) aRow
|
|
|
|
withFID: (uint64_t) fid
|
|
|
|
inParentFID: (uint64_t) parentFID
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSString *folderURL, *parentFolderURL;
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
|
|
|
|
|
|
|
folderURL = [mapping urlFromID: fid];
|
|
|
|
if (folderURL)
|
|
|
|
rc = MAPISTORE_ERR_EXIST;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
parentFolderURL = [mapping urlFromID: parentFID];
|
|
|
|
if (!parentFolderURL)
|
|
|
|
[self errorWithFormat: @"No url found for FID: %lld", parentFID];
|
|
|
|
if (parentFolderURL) {
|
|
|
|
folderURL = [self _createFolder: aRow inParentURL: parentFolderURL];
|
|
|
|
if (folderURL) {
|
|
|
|
[mapping registerURL: folderURL withID: fid];
|
|
|
|
// if ([sogoFolder isKindOfClass: SOGoMailAccountK])
|
|
|
|
// [sogoFolder subscribe];
|
|
|
|
rc = MAPISTORE_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
else
|
|
|
|
rc = MAPISTORE_ERR_NOT_FOUND;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
rc = MAPISTORE_ERR_NO_DIRECTORY;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
\details Delete a folder from the sogo backend
|
|
|
|
|
|
|
|
\param private_data pointer to the current sogo context
|
|
|
|
\param parentFID the FID for the parent of the folder to delete
|
|
|
|
\param fid the FID for the folder to delete
|
|
|
|
|
|
|
|
\return MAPISTORE_SUCCESS on success, otherwise MAPISTORE_ERROR
|
2010-10-01 22:35:29 +02:00
|
|
|
*/
|
2010-10-01 20:54:30 +02:00
|
|
|
- (int) rmDirWithFID: (uint64_t) fid
|
|
|
|
inParentFID: (uint64_t) parentFid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPISTORE_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
\details Open a folder from the sogo backend
|
|
|
|
|
|
|
|
\param private_data pointer to the current sogo context
|
|
|
|
\param parentFID the parent folder identifier
|
|
|
|
\param fid the identifier of the colder to open
|
|
|
|
|
|
|
|
\return MAPISTORE_SUCCESS on success, otherwise MAPISTORE_ERROR
|
2010-10-01 22:35:29 +02:00
|
|
|
*/
|
2010-10-01 20:54:30 +02:00
|
|
|
- (int) openDir: (uint64_t) fid
|
|
|
|
inParentFID: (uint64_t) parentFID
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPISTORE_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
\details Close a folder from the sogo backend
|
|
|
|
|
|
|
|
\param private_data pointer to the current sogo context
|
|
|
|
|
|
|
|
\return MAPISTORE_SUCCESS on success, otherwise MAPISTORE_ERROR
|
2010-10-01 22:35:29 +02:00
|
|
|
*/
|
2010-10-01 20:54:30 +02:00
|
|
|
- (int) closeDir
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPISTORE_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (NSArray *) _messageKeysForFolderURL: (NSString *) folderURL
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSArray *keys;
|
|
|
|
SOGoFolder *folder;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
keys = [messageCache objectForKey: folderURL];
|
|
|
|
if (!keys)
|
|
|
|
{
|
|
|
|
folder = [self lookupObject: folderURL];
|
|
|
|
if (folder)
|
2010-10-01 23:24:15 +02:00
|
|
|
keys = [self getFolderMessageKeys: folder];
|
2010-10-01 22:35:29 +02:00
|
|
|
else
|
|
|
|
keys = (NSArray *) [NSNull null];
|
|
|
|
[messageCache setObject: keys forKey: folderURL];
|
|
|
|
}
|
|
|
|
|
|
|
|
return keys;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
2010-10-01 23:24:15 +02:00
|
|
|
- (NSArray *) getFolderMessageKeys: (SOGoFolder *) folder
|
|
|
|
{
|
|
|
|
[self subclassResponsibility: _cmd];
|
|
|
|
|
|
|
|
return (NSArray *) [NSNull null];
|
|
|
|
}
|
|
|
|
|
2010-10-01 20:54:30 +02:00
|
|
|
- (NSArray *) _subfolderKeysForFolderURL: (NSString *) folderURL
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSArray *keys;
|
|
|
|
SOGoFolder *folder;
|
|
|
|
|
|
|
|
keys = [subfolderCache objectForKey: folderURL];
|
|
|
|
if (!keys)
|
|
|
|
{
|
|
|
|
folder = [self lookupObject: folderURL];
|
|
|
|
if (folder)
|
|
|
|
{
|
|
|
|
keys = [folder toManyRelationshipKeys];
|
|
|
|
if (!keys)
|
|
|
|
keys = (NSArray *) [NSNull null];
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
else
|
|
|
|
keys = (NSArray *) [NSNull null];
|
|
|
|
[subfolderCache setObject: keys forKey: folderURL];
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return keys;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
\details Read directory content from the sogo backend
|
|
|
|
|
|
|
|
\param private_data pointer to the current sogo context
|
|
|
|
|
|
|
|
\return MAPISTORE_SUCCESS on success, otherwise MAPISTORE_ERROR
|
2010-10-01 22:35:29 +02:00
|
|
|
*/
|
2010-10-01 20:54:30 +02:00
|
|
|
- (int) readCount: (uint32_t *) rowCount
|
|
|
|
ofTableType: (uint8_t) tableType
|
|
|
|
inFID: (uint64_t) fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSArray *ids;
|
|
|
|
NSString *url;
|
|
|
|
int rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
url = [mapping urlFromID: fid];
|
|
|
|
if (!url)
|
|
|
|
[self errorWithFormat: @"No url found for FID: %lld", fid];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
switch (tableType)
|
|
|
|
{
|
|
|
|
case MAPISTORE_FOLDER_TABLE:
|
|
|
|
ids = [self _subfolderKeysForFolderURL: url];
|
|
|
|
break;
|
|
|
|
case MAPISTORE_MESSAGE_TABLE:
|
|
|
|
ids = [self _messageKeysForFolderURL: url];
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
rc = MAPISTORE_ERR_INVALID_PARAMETER;
|
|
|
|
ids = nil;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
if ([ids isKindOfClass: [NSArray class]])
|
|
|
|
{
|
|
|
|
rc = MAPI_E_SUCCESS;
|
|
|
|
*rowCount = [ids count];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
rc = MAPISTORE_ERR_NO_DIRECTORY;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) getCommonTableChildproperty: (void **) data
|
|
|
|
atURL: (NSString *) childURL
|
|
|
|
withTag: (uint32_t) proptag
|
|
|
|
inFolder: (SOGoFolder *) folder
|
|
|
|
withFID: (uint64_t) fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSString *stringValue;
|
|
|
|
id child;
|
|
|
|
// uint64_t *llongValue;
|
|
|
|
// uint32_t *longValue;
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
rc = MAPI_E_SUCCESS;
|
|
|
|
switch (proptag)
|
|
|
|
{
|
|
|
|
case PR_DISPLAY_NAME_UNICODE:
|
|
|
|
child = [self lookupObject: childURL];
|
|
|
|
*data = [[child displayName] asUnicodeInMemCtx: memCtx];
|
|
|
|
break;
|
|
|
|
default:
|
2010-10-05 15:56:43 +02:00
|
|
|
*data = NULL;
|
|
|
|
rc = MAPI_E_NOT_FOUND;
|
2010-10-01 22:35:29 +02:00
|
|
|
if ((proptag & 0x001F) == 0x001F)
|
|
|
|
{
|
|
|
|
stringValue = [NSString stringWithFormat: @"Unhandled unicode value: 0x%x", proptag];
|
|
|
|
*data = [stringValue asUnicodeInMemCtx: memCtx];
|
2010-10-05 15:56:43 +02:00
|
|
|
rc = MAPI_E_SUCCESS;
|
2010-10-01 22:35:29 +02:00
|
|
|
[self errorWithFormat: @"Unknown proptag (returned): %.8x for child '%@'",
|
|
|
|
proptag, childURL];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
[self errorWithFormat: @"Unknown proptag: %.8x for child '%@'",
|
|
|
|
proptag, childURL];
|
2010-10-05 15:56:43 +02:00
|
|
|
// *data = NULL;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) getMessageTableChildproperty: (void **) data
|
|
|
|
atURL: (NSString *) childURL
|
|
|
|
withTag: (uint32_t) proptag
|
|
|
|
inFolder: (SOGoFolder *) folder
|
|
|
|
withFID: (uint64_t) fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
int rc;
|
2010-10-06 16:27:09 +02:00
|
|
|
int64_t mappingId;
|
2010-10-01 22:35:29 +02:00
|
|
|
|
|
|
|
rc = MAPI_E_SUCCESS;
|
|
|
|
switch (proptag)
|
|
|
|
{
|
|
|
|
case PR_INST_ID: // TODO: DOUBT
|
2010-10-06 16:27:09 +02:00
|
|
|
/* we return a unique id based on the url */
|
|
|
|
*data = MAPILongLongValue (memCtx, [childURL hash]);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
// case PR_INST_ID: // TODO: DOUBT
|
2010-10-06 15:59:49 +02:00
|
|
|
case PR_DEPTH: // TODO: DOUBT
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPILongLongValue (memCtx, 0);
|
2010-10-06 15:59:49 +02:00
|
|
|
break;
|
|
|
|
case PR_ROW_TYPE: // TODO: DOUBT
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPILongValue (memCtx, TBL_LEAF_ROW);
|
2010-10-06 15:59:49 +02:00
|
|
|
break;
|
2010-10-01 22:35:29 +02:00
|
|
|
case PR_INSTANCE_NUM: // TODO: DOUBT
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPILongValue (memCtx, 0);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
case PR_VD_VERSION:
|
2010-10-06 16:27:09 +02:00
|
|
|
/* mandatory value... wtf? */
|
|
|
|
*data = MAPILongValue (memCtx, 8);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
case PR_FID:
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPILongLongValue (memCtx, fid);
|
2010-10-01 22:35:29 +02:00
|
|
|
case PR_MID:
|
2010-10-06 16:27:09 +02:00
|
|
|
mappingId = [mapping idFromURL: childURL];
|
|
|
|
if (mappingId == NSNotFound)
|
|
|
|
{
|
|
|
|
[mapping registerURL: childURL];
|
|
|
|
mappingId = [mapping idFromURL: childURL];
|
|
|
|
}
|
|
|
|
*data = MAPILongLongValue (memCtx, mappingId);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
/* those are queried while they really pertain to the
|
|
|
|
addressbook module */
|
|
|
|
// #define PR_OAB_LANGID PROP_TAG(PT_LONG , 0x6807) /* 0x68070003 */
|
|
|
|
// case PR_OAB_NAME_UNICODE:
|
|
|
|
// case PR_OAB_CONTAINER_GUID_UNICODE:
|
|
|
|
|
|
|
|
// 0x68420102 PidTagScheduleInfoDelegatorWantsCopy (BOOL)
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
rc = [self getCommonTableChildproperty: data
|
|
|
|
atURL: childURL
|
|
|
|
withTag: proptag
|
|
|
|
inFolder: folder
|
|
|
|
withFID: fid];
|
|
|
|
}
|
|
|
|
|
|
|
|
return rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (NSString *) _parentURLFromURL: (NSString *) urlString
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSString *newURL;
|
|
|
|
NSArray *parts;
|
|
|
|
NSMutableArray *newParts;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
parts = [urlString componentsSeparatedByString: @"/"];
|
|
|
|
if ([parts count] > 3)
|
|
|
|
{
|
|
|
|
newParts = [parts mutableCopy];
|
|
|
|
[newParts autorelease];
|
|
|
|
[newParts removeLastObject];
|
|
|
|
newURL = [newParts componentsJoinedByString: @"/"];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
newURL = nil;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return newURL;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) getFolderTableChildproperty: (void **) data
|
|
|
|
atURL: (NSString *) childURL
|
|
|
|
withTag: (uint32_t) proptag
|
|
|
|
inFolder: (SOGoFolder *) folder
|
|
|
|
withFID: (uint64_t) fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
// id child;
|
|
|
|
struct Binary_r *binaryValue;
|
2010-10-06 16:27:09 +02:00
|
|
|
int64_t mappingId;
|
2010-10-01 22:35:29 +02:00
|
|
|
int rc;
|
|
|
|
NSString *parentURL;
|
|
|
|
|
|
|
|
rc = MAPI_E_SUCCESS;
|
|
|
|
switch (proptag)
|
|
|
|
{
|
|
|
|
case PR_FID:
|
2010-10-06 16:27:09 +02:00
|
|
|
mappingId = [mapping idFromURL: childURL];
|
|
|
|
if (mappingId == NSNotFound)
|
2010-10-01 22:35:29 +02:00
|
|
|
{
|
|
|
|
[mapping registerURL: childURL];
|
2010-10-06 16:27:09 +02:00
|
|
|
mappingId = [mapping idFromURL: childURL];
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPILongLongValue (memCtx, mappingId);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
case PR_PARENT_FID:
|
|
|
|
parentURL = [self _parentURLFromURL: childURL];
|
|
|
|
if (parentURL)
|
|
|
|
{
|
2010-10-06 16:27:09 +02:00
|
|
|
mappingId = [mapping idFromURL: parentURL];
|
|
|
|
if (mappingId == NSNotFound)
|
2010-10-01 22:35:29 +02:00
|
|
|
{
|
2010-10-06 16:27:09 +02:00
|
|
|
[mapping registerURL: parentURL];
|
|
|
|
mappingId = [mapping idFromURL: parentURL];
|
2010-10-01 22:35:29 +02:00
|
|
|
}
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPILongLongValue (memCtx, mappingId);
|
2010-10-01 22:35:29 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
*data = NULL;
|
|
|
|
rc = MAPISTORE_ERR_NOT_FOUND;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PR_ATTR_HIDDEN:
|
|
|
|
case PR_ATTR_SYSTEM:
|
|
|
|
case PR_ATTR_READONLY:
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPIBoolValue (memCtx, NO);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
case PR_SUBFOLDERS:
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPIBoolValue (memCtx,
|
|
|
|
[[self _subfolderKeysForFolderURL: childURL]
|
|
|
|
count] > 0);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
case PR_CONTENT_COUNT:
|
2010-10-06 16:27:09 +02:00
|
|
|
*data = MAPILongValue (memCtx,
|
|
|
|
[[self _messageKeysForFolderURL: childURL]
|
|
|
|
count]);
|
2010-10-01 22:35:29 +02:00
|
|
|
break;
|
|
|
|
case PR_EXTENDED_FOLDER_FLAGS: // TODO: DOUBT: how to indicate the
|
|
|
|
// number of subresponses ?
|
|
|
|
binaryValue = talloc_zero(memCtx, struct Binary_r);
|
|
|
|
*data = binaryValue;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
rc = [self getCommonTableChildproperty: data
|
|
|
|
atURL: childURL
|
|
|
|
withTag: proptag
|
|
|
|
inFolder: folder
|
|
|
|
withFID: fid];
|
|
|
|
}
|
|
|
|
|
|
|
|
return rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) getTableProperty: (void **) data
|
|
|
|
withTag: (uint32_t) proptag
|
|
|
|
atPosition: (uint32_t) pos
|
|
|
|
withTableType: (uint8_t) tableType
|
|
|
|
inFID: (uint64_t) fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
NSArray *children;
|
|
|
|
NSString *folderURL, *childURL, *childName;
|
|
|
|
SOGoFolder *folder;
|
|
|
|
int rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d) -- proptag: 0x%.8x, pos: %ld, tableType: %d, fid: %lld",
|
|
|
|
__FUNCTION__, __LINE__, proptag, pos, tableType, fid];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
folderURL = [mapping urlFromID: fid];
|
|
|
|
if (folderURL)
|
|
|
|
{
|
|
|
|
folder = [self lookupObject: folderURL];
|
|
|
|
switch (tableType)
|
|
|
|
{
|
|
|
|
case MAPISTORE_FOLDER_TABLE:
|
|
|
|
children = [self _subfolderKeysForFolderURL: folderURL];
|
|
|
|
break;
|
|
|
|
case MAPISTORE_MESSAGE_TABLE:
|
|
|
|
children = [self _messageKeysForFolderURL: folderURL];
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
children = nil;
|
|
|
|
break;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
if ([children count] > pos)
|
|
|
|
{
|
|
|
|
childName = [children objectAtIndex: pos];
|
|
|
|
childURL = [folderURL stringByAppendingFormat: @"/%@",
|
|
|
|
[childName stringByEscapingURL]];
|
|
|
|
|
|
|
|
if (tableType == MAPISTORE_FOLDER_TABLE)
|
|
|
|
{
|
|
|
|
[self logWithFormat: @" querying child folder at URL: %@", childURL];
|
|
|
|
rc = [self getFolderTableChildproperty: data
|
|
|
|
atURL: childURL
|
|
|
|
withTag: proptag
|
|
|
|
inFolder: folder
|
|
|
|
withFID: fid];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
[self logWithFormat: @" querying child message at URL: %@", childURL];
|
|
|
|
rc = [self getMessageTableChildproperty: data
|
|
|
|
atURL: childURL
|
|
|
|
withTag: proptag
|
|
|
|
inFolder: folder
|
|
|
|
withFID: fid];
|
|
|
|
}
|
|
|
|
/* Unhandled: */
|
|
|
|
// #define PR_EXPIRY_TIME PROP_TAG(PT_SYSTIME , 0x0015) /* 0x00150040 */
|
|
|
|
// #define PR_REPLY_TIME PROP_TAG(PT_SYSTIME , 0x0030) /* 0x00300040 */
|
|
|
|
// #define PR_SENSITIVITY PROP_TAG(PT_LONG , 0x0036) /* 0x00360003 */
|
|
|
|
// #define PR_MESSAGE_DELIVERY_TIME PROP_TAG(PT_SYSTIME , 0x0e06) /* 0x0e060040 */
|
|
|
|
// #define PR_FOLLOWUP_ICON PROP_TAG(PT_LONG , 0x1095) /* 0x10950003 */
|
|
|
|
// #define PR_ITEM_TEMPORARY_FLAGS PROP_TAG(PT_LONG , 0x1097) /* 0x10970003 */
|
|
|
|
// #define PR_SEARCH_KEY PROP_TAG(PT_BINARY , 0x300b) /* 0x300b0102 */
|
|
|
|
// #define PR_CONTENT_COUNT PROP_TAG(PT_LONG , 0x3602) /* 0x36020003 */
|
|
|
|
// #define PR_CONTENT_UNREAD PROP_TAG(PT_LONG , 0x3603) /* 0x36030003 */
|
|
|
|
// #define PR_FID PROP_TAG(PT_I8 , 0x6748) /* 0x67480014 */
|
|
|
|
// unknown 36de0003 http://social.msdn.microsoft.com/Forums/en-US/os_exchangeprotocols/thread/17c68add-1f62-4b68-9d83-f9ec7c1c6c9b
|
|
|
|
// unknown 819d0003
|
|
|
|
// unknown 81f80003
|
|
|
|
// unknown 81fa000b
|
2010-10-01 20:54:30 +02:00
|
|
|
|
|
|
|
}
|
2010-10-01 22:35:29 +02:00
|
|
|
else
|
|
|
|
rc = MAPISTORE_ERROR;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
[self errorWithFormat: @"No url found for FID: %lld", fid];
|
|
|
|
rc = MAPISTORE_ERR_NOT_FOUND;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return rc;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
- (int) openMessage: (struct mapistore_message *) msg
|
|
|
|
withMID: (uint64_t) mid
|
|
|
|
inFID: (uint64_t) fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPI_E_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) createMessageWithMID: (uint64_t) mid
|
|
|
|
inFID: (uint64_t) fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPI_E_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) saveChangesInMessageWithMID: (uint64_t) mid
|
|
|
|
andFlags: (uint8_t) flags
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPI_E_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) submitMessageWithMID: (uint64_t) mid
|
|
|
|
andFlags: (uint8_t) flags
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPI_E_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) getProperties: (struct SPropTagArray *) SPropTagArray
|
|
|
|
inRow: (struct SRow *) aRow
|
|
|
|
withMID: (uint64_t) fmid
|
|
|
|
type: (uint8_t) tableType
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d) -- tableType: %d, mid: %lld",
|
|
|
|
__FUNCTION__, __LINE__, tableType, fmid];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
switch (tableType)
|
|
|
|
{
|
|
|
|
case MAPISTORE_FOLDER:
|
|
|
|
break;
|
|
|
|
case MAPISTORE_MESSAGE:
|
|
|
|
break;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPI_E_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) getFID: (uint64_t *) fid
|
|
|
|
byName: (const char *) foldername
|
|
|
|
inParentFID: (uint64_t) parent_fid
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d) -- foldername: %s, parent_fid: %lld",
|
|
|
|
__FUNCTION__, __LINE__, foldername, parent_fid];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPISTORE_ERR_INVALID_PARAMETER;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) setPropertiesWithMID: (uint64_t) fmid
|
|
|
|
type: (uint8_t) type
|
|
|
|
inRow: (struct SRow *) aRow
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
switch (type)
|
|
|
|
{
|
|
|
|
case MAPISTORE_FOLDER:
|
|
|
|
break;
|
|
|
|
case MAPISTORE_MESSAGE:
|
|
|
|
break;
|
|
|
|
}
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPI_E_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
- (int) deleteMessageWithMID: (uint64_t) mid
|
|
|
|
withFlags: (uint8_t) flags
|
|
|
|
{
|
2010-10-01 22:35:29 +02:00
|
|
|
[self logWithFormat: @"METHOD '%s' (%d)", __FUNCTION__, __LINE__];
|
2010-10-01 20:54:30 +02:00
|
|
|
|
2010-10-01 22:35:29 +02:00
|
|
|
return MAPI_E_SUCCESS;
|
2010-10-01 20:54:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@end
|