Monotone-Parent: e3553800558b6ad8617dd801a3ff4822695f8d62

Monotone-Revision: 0cc4395b1707eacba015ff4c4d76225c0c3fbc0e

Monotone-Author: wsourdeau@inverse.ca
Monotone-Date: 2011-03-31T22:05:33
Monotone-Branch: ca.inverse.sogo
maint-2.0.2
Wolfgang Sourdeau 2011-03-31 22:05:33 +00:00
parent d52a73e213
commit 7534ab9204
3 changed files with 120 additions and 2 deletions

View File

@ -1,5 +1,17 @@
2011-03-31 Wolfgang Sourdeau <wsourdeau@inverse.ca>
* OpenChange/MAPIStoreAttachment.m (-nameInContainer): overriden
method to return "aid" in the form of a NSString.
(-mimeAttachTag): new helper method derived from old code in
getProperty:withTag: for subclasses.
(-getProperty:withTag:): handles PR_MID, PR_ATTACH_NUM and
PR_RENDERING_POSITION, previously found in
MAPIStoreMailAttachment.
(-openEmbeddedMessage:withMID:withMAPIStoreMsg:andFlags:): new
backend method.
(-openEmbeddedMessage, -createEmbeddedMessage): new overridable
methods.
* OpenChange/MAPIStoreEmbeddedMessage.[hm]: new class module for
attachment embedded messages.

View File

@ -25,6 +25,8 @@
#import "MAPIStoreObject.h"
@class MAPIStoreAttachmentMessage;
@interface MAPIStoreAttachment : MAPIStoreObject
{
uint32_t aid;
@ -33,6 +35,18 @@
- (void) setAID: (uint32_t) newAID;
- (uint32_t) AID;
- (int) openEmbeddedMessage: (void **) message
withMID: (uint64_t *) mid
withMAPIStoreMsg: (struct mapistore_message *) mapistoreMsg
andFlags: (enum OpenEmbeddedMessage_OpenModeFlags) flags;
/* helpers */
- (NSData *) mimeAttachTag;
/* subclasses */
- (MAPIStoreAttachmentMessage *) openEmbeddedMessage;
- (MAPIStoreAttachmentMessage *) createEmbeddedMessage;
@end
#endif /* MAPISTOREATTACHMENT_H */

View File

@ -20,14 +20,28 @@
* Boston, MA 02111-1307, USA.
*/
#import "MAPIStoreAttachment.h"
#import <Foundation/NSData.h>
#import "MAPIStoreAttachment.h"
#import "MAPIStoreMapping.h"
#import "MAPIStoreMessage.h"
#import "MAPIStoreTypes.h"
#undef DEBUG
#include <stdbool.h>
#include <gen_ndr/exchange.h>
#include <mapistore/mapistore.h>
#include <mapistore/mapistore_errors.h>
static MAPIStoreMapping *mapping;
@implementation MAPIStoreAttachment
+ (void) initialize
{
mapping = [MAPIStoreMapping sharedMapping];
}
- (void) setAID: (uint32_t) newAID
{
aid = newAID;
@ -38,10 +52,88 @@
return aid;
}
- (NSString *) nameInContainer
{
return [NSString stringWithFormat: @"%d", aid];
}
- (NSData *) mimeAttachTag
{
static NSData *mimeAttachTag = nil;
char tagBytes[] = {0x2a, 0x86, 0x48, 0x86, 0xf7, 0x14, 0x03, 0x0a, 0x04};
if (!mimeAttachTag)
{
mimeAttachTag = [NSData dataWithBytes: tagBytes length: 9];
[mimeAttachTag retain];
}
return mimeAttachTag;
}
- (int) getProperty: (void **) data
withTag: (enum MAPITAGS) propTag
{
return MAPISTORE_ERR_NOT_FOUND;
int rc;
rc = MAPISTORE_SUCCESS;
switch (propTag)
{
case PR_MID:
*data = MAPILongLongValue (memCtx, [container objectId]);
break;
case PR_ATTACH_NUM:
*data = MAPILongValue (memCtx, aid);
break;
case PR_RENDERING_POSITION:
*data = MAPILongValue (memCtx, 0xffffffff);
break;
default:
rc = MAPISTORE_ERR_NOT_FOUND;
}
return rc;
}
- (int) openEmbeddedMessage: (void **) message
withMID: (uint64_t *) mid
withMAPIStoreMsg: (struct mapistore_message *) mapistoreMsg
andFlags: (enum OpenEmbeddedMessage_OpenModeFlags) flags
{
MAPIStoreAttachmentMessage *attMessage;
memset (mapistoreMsg, 0, sizeof (struct mapistore_message));
attMessage = [self openEmbeddedMessage];
if (attMessage)
*mid = [mapping idFromURL: [attMessage url]];
else if (flags == MAPI_CREATE)
{
attMessage = [self createEmbeddedMessage];
if (attMessage)
[mapping registerURL: [attMessage url]
withID: *mid];
}
*message = attMessage;
[attMessage retain];
return (attMessage ? MAPISTORE_SUCCESS : MAPISTORE_ERROR);
}
/* subclasses */
- (MAPIStoreAttachmentMessage *) openEmbeddedMessage
{
[self subclassResponsibility: _cmd];
return nil;
}
- (MAPIStoreAttachmentMessage *) createEmbeddedMessage
{
[self subclassResponsibility: _cmd];
return nil;
}
@end