property.c File Reference

Functions for manipulating MAPI properties. More...

#include "libmapi/libmapi.h"
#include "libmapi/libmapi_private.h"

Functions

_PUBLIC_ struct mapi_SPropValue * add_mapi_SPropValue (TALLOC_CTX *mem_ctx, struct mapi_SPropValue *lpProps, uint16_t *cValues, uint32_t aulPropTag, const void *data)
_PUBLIC_ struct SPropValue * add_SPropValue (TALLOC_CTX *mem_ctx, struct SPropValue *lpProps, uint32_t *cValues, enum MAPITAGS aulPropTag, const void *data)
_PUBLIC_ uint32_t cast_mapi_SPropValue (TALLOC_CTX *mem_ctx, struct mapi_SPropValue *mapi_sprop, struct SPropValue *sprop)
_PUBLIC_ uint32_t cast_SPropValue (TALLOC_CTX *mem_ctx, struct mapi_SPropValue *mapi_sprop, struct SPropValue *sprop)
_PUBLIC_ const void * find_mapi_SPropValue_data (struct mapi_SPropValue_array *properties, uint32_t mapitag)
_PUBLIC_ const void * find_SPropValue_data (struct SRow *aRow, uint32_t mapitag)
_PUBLIC_ struct
AddressBookEntryId * 
get_AddressBookEntryId (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ struct
AppointmentRecurrencePattern * 
get_AppointmentRecurrencePattern (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ struct FolderEntryId * get_FolderEntryId (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ struct GlobalObjectId * get_GlobalObjectId (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ uint32_t get_mapi_property_size (struct mapi_SPropValue *lpProp)
_PUBLIC_ enum MAPISTATUS get_mapi_SPropValue_array_date_timeval (struct timeval *t, struct mapi_SPropValue_array *properties, uint32_t mapitag)
_PUBLIC_ const void * get_mapi_SPropValue_data (struct mapi_SPropValue *lpProp)
_PUBLIC_ enum MAPISTATUS get_mapi_SPropValue_date_timeval (struct timeval *t, struct SPropValue lpProp)
enum MAPITAGS * get_MAPITAGS_SRow (TALLOC_CTX *mem_ctx, struct SRow *aRow, uint32_t *actual_count)
_PUBLIC_ struct MessageEntryId * get_MessageEntryId (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ struct PtypServerId * get_PtypServerId (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ struct RecurrencePattern * get_RecurrencePattern (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ const void * get_SPropValue (struct SPropValue *lpProps, enum MAPITAGS ulPropTag)
_PUBLIC_ const void * get_SPropValue_data (struct SPropValue *lpProps)
_PUBLIC_ struct SPropValue * get_SPropValue_SRow (struct SRow *aRow, uint32_t ulPropTag)
_PUBLIC_ const void * get_SPropValue_SRow_data (struct SRow *aRow, uint32_t ulPropTag)
_PUBLIC_ struct SPropValue * get_SPropValue_SRowSet (struct SRowSet *RowSet, uint32_t ulPropTag)
_PUBLIC_ const void * get_SPropValue_SRowSet_data (struct SRowSet *RowSet, uint32_t ulPropTag)
_PUBLIC_ struct TimeZoneStruct * get_TimeZoneStruct (TALLOC_CTX *mem_ctx, struct Binary_r *bin)
_PUBLIC_ const char * get_TypedString (struct TypedString *tstring)
size_t get_utf8_utf16_conv_length (const char *inbuf)
_PUBLIC_ void mapi_copy_spropvalues (TALLOC_CTX *mem_ctx, struct SPropValue *source_values, struct SPropValue *dest_values, uint32_t count)
_PUBLIC_ void mapi_SPropValue_array_named (mapi_object_t *obj, struct mapi_SPropValue_array *props)
uint32_t MAPITAGS_delete_entries (enum MAPITAGS *mapitags, uint32_t final_count, uint32_t PropCount,...)
_PUBLIC_ struct Binary_r * set_AppointmentRecurrencePattern (TALLOC_CTX *mem_ctx, const struct AppointmentRecurrencePattern *arp)
_PUBLIC_ size_t set_AppointmentRecurrencePattern_size (const struct AppointmentRecurrencePattern *arp)
_PUBLIC_ enum MAPISTATUS set_default_error_SPropValue_SRow (struct SRow *aRow, enum MAPITAGS ulPropTag, void *data)
_PUBLIC_ size_t set_ExceptionInfo_size (const struct ExceptionInfo *exc_info)
_PUBLIC_ bool set_mapi_SPropValue (TALLOC_CTX *mem_ctx, struct mapi_SPropValue *lpProps, const void *data)
_PUBLIC_ bool set_mapi_SPropValue_proptag (TALLOC_CTX *mem_ctx, struct mapi_SPropValue *lpProps, uint32_t aulPropTag, const void *data)
_PUBLIC_ struct Binary_r * set_RecurrencePattern (TALLOC_CTX *mem_ctx, const struct RecurrencePattern *rp)
_PUBLIC_ size_t set_RecurrencePattern_size (const struct RecurrencePattern *rp)
_PUBLIC_ struct SPropTagArray * set_SPropTagArray (TALLOC_CTX *mem_ctx, uint32_t PropCount,...)
_PUBLIC_ bool set_SPropValue (struct SPropValue *lpProps, const void *data)
_PUBLIC_ bool set_SPropValue_proptag (struct SPropValue *lpProps, enum MAPITAGS aulPropTag, const void *data)
_PUBLIC_ bool set_SPropValue_proptag_date_timeval (struct SPropValue *lpProps, enum MAPITAGS aulPropTag, const struct timeval *t)
_PUBLIC_ enum MAPISTATUS SPropTagArray_add (TALLOC_CTX *mem_ctx, struct SPropTagArray *SPropTagArray, enum MAPITAGS aulPropTag)
_PUBLIC_ enum MAPISTATUS SPropTagArray_delete (TALLOC_CTX *mem_ctx, struct SPropTagArray *SPropTagArray, uint32_t aulPropTag)
_PUBLIC_ enum MAPISTATUS SPropTagArray_find (struct SPropTagArray SPropTagArray, enum MAPITAGS aulPropTag, uint32_t *propIdx)
_PUBLIC_ enum MAPISTATUS SRow_addprop (struct SRow *aRow, struct SPropValue spropvalue)
_PUBLIC_ uint32_t SRowSet_propcpy (TALLOC_CTX *mem_ctx, struct SRowSet *SRowSet, struct SPropValue spropvalue)

Detailed Description

Functions for manipulating MAPI properties.

Function Documentation

_PUBLIC_ struct mapi_SPropValue* add_mapi_SPropValue ( TALLOC_CTX *  mem_ctx,
struct mapi_SPropValue *  lpProps,
uint16_t *  cValues,
uint32_t  aulPropTag,
const void *  data 
)
read
_PUBLIC_ struct SPropValue* add_SPropValue ( TALLOC_CTX *  mem_ctx,
struct SPropValue *  lpProps,
uint32_t *  cValues,
enum MAPITAGS  aulPropTag,
const void *  data 
)
read
_PUBLIC_ uint32_t cast_mapi_SPropValue ( TALLOC_CTX *  mem_ctx,
struct mapi_SPropValue *  mapi_sprop,
struct SPropValue *  sprop 
)

Convenience function to convert a SPropValue structure into a mapi_SPropValue structure and return the associated size.

Parameters
mem_ctxpointer to the memory context to use for allocation
mapi_sproppointer to the MAPI SPropValue structure to copy data to
sproppointer to the SPropValue structure to copy data from
Returns
size of the converted data on success, otherwise 0

References get_utf8_utf16_conv_length(), PT_BINARY, PT_BOOLEAN, PT_CLSID, PT_DOUBLE, PT_ERROR, PT_I2, PT_I8, PT_LONG, PT_MV_BINARY, PT_MV_CLSID, PT_MV_LONG, PT_MV_STRING8, PT_MV_UNICODE, PT_STRING8, PT_SVREID, PT_SYSTIME, and PT_UNICODE.

Referenced by AddUserPermission(), ModifyRecipients(), SetPropertiesNoReplicate(), and SetProps().

_PUBLIC_ uint32_t cast_SPropValue ( TALLOC_CTX *  mem_ctx,
struct mapi_SPropValue *  mapi_sprop,
struct SPropValue *  sprop 
)

Convenience function to convert a mapi_SPropValue structure into a SPropValue structure and return the associated size

Parameters
mem_ctxpointer to the memory context to use for allocation
mapi_sproppointer to the MAPI SPropValue structure to copy data from
sproppointer to the SPropValue structure to copy data to
Returns
size of the converted data on success, otherwise 0

References get_utf8_utf16_conv_length(), PT_BINARY, PT_BOOLEAN, PT_CLSID, PT_DOUBLE, PT_ERROR, PT_I2, PT_I8, PT_LONG, PT_MV_BINARY, PT_MV_CLSID, PT_MV_LONG, PT_MV_STRING8, PT_MV_UNICODE, PT_STRING8, PT_SVREID, PT_SYSTIME, and PT_UNICODE.

_PUBLIC_ const void* find_mapi_SPropValue_data ( struct mapi_SPropValue_array *  properties,
uint32_t  mapitag 
)
_PUBLIC_ const void* find_SPropValue_data ( struct SRow *  aRow,
uint32_t  mapitag 
)
_PUBLIC_ struct AddressBookEntryId* get_AddressBookEntryId ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read

Retrieve a AddressBookEntryId structure from a binary blob

Parameters
mem_ctxpointer to the memory context
binpointer to the Binary_r structure with raw AddressBookEntryId data
Returns
Allocated AddressBookEntryId structure on success, otherwise NULL
Note
Developers must free the allocated AddressBookEntryId when finished.
_PUBLIC_ struct AppointmentRecurrencePattern* get_AppointmentRecurrencePattern ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read
_PUBLIC_ struct FolderEntryId* get_FolderEntryId ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read

Retrieve a FolderEntryId structure from a binary blob

Parameters
mem_ctxpointer to the memory context
binpointer to the Binary_r structure with raw FolderEntryId data
Returns
Allocated FolderEntryId structure on success, otherwise NULL
Note
Developers must free the allocated FolderEntryId when finished.
_PUBLIC_ struct GlobalObjectId* get_GlobalObjectId ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read

Retrieve a GlobalObjectId structure from a binary blob

Parameters
mem_ctxpointer to the memory context
binpointer to the Binary_r structure with raw GlobalObjectId data
Returns
Allocated GlobalObjectId structure on success, otherwise NULL
Note
Developers must free the allocated GlobalObjectId when finished.
_PUBLIC_ uint32_t get_mapi_property_size ( struct mapi_SPropValue *  lpProp)
_PUBLIC_ enum MAPISTATUS get_mapi_SPropValue_array_date_timeval ( struct timeval *  t,
struct mapi_SPropValue_array *  properties,
uint32_t  mapitag 
)
_PUBLIC_ const void* get_mapi_SPropValue_data ( struct mapi_SPropValue *  lpProp)
_PUBLIC_ enum MAPISTATUS get_mapi_SPropValue_date_timeval ( struct timeval *  t,
struct SPropValue  lpProp 
)

References get_SPropValue_data().

enum MAPITAGS* get_MAPITAGS_SRow ( TALLOC_CTX *  mem_ctx,
struct SRow *  aRow,
uint32_t *  actual_count 
)

References PT_ERROR.

Referenced by ModifyRecipients().

_PUBLIC_ struct MessageEntryId* get_MessageEntryId ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read

Retrieve a MessageEntryId structure from a binary blob

Parameters
mem_ctxpointer to the memory context
binpointer to the Binary_r structure with raw MessageEntryId data
Returns
Allocated MessageEntryId structure on success, otherwise NULL
Note
Developers must free the allocated MessageEntryId when finished.
_PUBLIC_ struct PtypServerId* get_PtypServerId ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read

Retrieve a PtypServerId structure from a binary blob

Parameters
mem_ctxpointer to the memory context
binpointer to the Binary_r structure with raw PtypServerId data
Returns
Allocated PtypServerId structure on success, otherwise NULL
Note
Developers must free the allocated PtypServerId when finished.
_PUBLIC_ struct RecurrencePattern* get_RecurrencePattern ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read

Retrieve a RecurrencePattern structure from a binary blob

Parameters
mem_ctxpointer to the memory context
binpointer to the Binary_r structure with non-mapped reccurrence data
Returns
Allocated RecurrencePattern structure on success, otherwise NULL
Note
Developers must free the allocated RecurrencePattern when finished.
_PUBLIC_ const void* get_SPropValue ( struct SPropValue *  lpProps,
enum MAPITAGS  ulPropTag 
)
_PUBLIC_ struct SPropValue* get_SPropValue_SRow ( struct SRow *  aRow,
uint32_t  ulPropTag 
)
read
_PUBLIC_ const void* get_SPropValue_SRow_data ( struct SRow *  aRow,
uint32_t  ulPropTag 
)
_PUBLIC_ struct SPropValue* get_SPropValue_SRowSet ( struct SRowSet *  RowSet,
uint32_t  ulPropTag 
)
read
_PUBLIC_ const void* get_SPropValue_SRowSet_data ( struct SRowSet *  RowSet,
uint32_t  ulPropTag 
)
_PUBLIC_ struct TimeZoneStruct* get_TimeZoneStruct ( TALLOC_CTX *  mem_ctx,
struct Binary_r *  bin 
)
read

Retrieve a TimeZoneStruct structure from a binary blob

Parameters
mem_ctxpointer to the memory context
binpointer to the Binary_r structure with raw TimeZoneStruct data
Returns
Allocated TimeZoneStruct structure on success, otherwise NULL
Note
Developers must free the allocated TimeZoneStruct when finished.
_PUBLIC_ const char* get_TypedString ( struct TypedString *  tstring)

Return the effective value used in a TypedString structure.

Parameters
tstringpointer to TypedString structure
Returns
pointer to a valid string on success, otherwise NULL

Referenced by OpenMessage().

size_t get_utf8_utf16_conv_length ( const char *  inbuf)

Return the expected size of the utf8 string after conversion to utf16 by iconv() function.

Parameters
inbufpointer to the input string
Returns
expected length of the converted string
Note
This routine is based upon utf8_pull() function from samba4/lib/util/charset/iconv.c

Referenced by cast_mapi_SPropValue(), cast_SPropValue(), CopyFolder(), CreateFolder(), get_mapi_property_size(), GetIDsFromNames(), mapi_nameid_canonical_add(), mapi_nameid_custom_string_add(), mapi_nameid_lid_add(), mapi_nameid_OOM_add(), mapi_nameid_string_add(), ModifyRecipients(), and MoveFolder().

_PUBLIC_ void mapi_copy_spropvalues ( TALLOC_CTX *  mem_ctx,
struct SPropValue *  source_values,
struct SPropValue *  dest_values,
uint32_t  count 
)

Convenience function to copy an array of struct SPropValue or a part thereof into another array, by duplicating and properly parenting pointer data. The destination array is considered to be preallocated.

References MV_FLAG, PT_BINARY, PT_STRING8, and PT_UNICODE.

_PUBLIC_ void mapi_SPropValue_array_named ( mapi_object_t obj,
struct mapi_SPropValue_array *  props 
)
uint32_t MAPITAGS_delete_entries ( enum MAPITAGS *  mapitags,
uint32_t  final_count,
uint32_t  PropCount,
  ... 
)

Referenced by ModifyRecipients().

_PUBLIC_ struct Binary_r* set_AppointmentRecurrencePattern ( TALLOC_CTX *  mem_ctx,
const struct AppointmentRecurrencePattern *  arp 
)
read
_PUBLIC_ size_t set_AppointmentRecurrencePattern_size ( const struct AppointmentRecurrencePattern *  arp)
_PUBLIC_ enum MAPISTATUS set_default_error_SPropValue_SRow ( struct SRow *  aRow,
enum MAPITAGS  ulPropTag,
void *  data 
)
_PUBLIC_ size_t set_ExceptionInfo_size ( const struct ExceptionInfo *  exc_info)
_PUBLIC_ bool set_mapi_SPropValue ( TALLOC_CTX *  mem_ctx,
struct mapi_SPropValue *  lpProps,
const void *  data 
)
_PUBLIC_ bool set_mapi_SPropValue_proptag ( TALLOC_CTX *  mem_ctx,
struct mapi_SPropValue *  lpProps,
uint32_t  aulPropTag,
const void *  data 
)

References set_mapi_SPropValue().

Referenced by add_mapi_SPropValue().

_PUBLIC_ struct Binary_r* set_RecurrencePattern ( TALLOC_CTX *  mem_ctx,
const struct RecurrencePattern *  rp 
)
read
_PUBLIC_ size_t set_RecurrencePattern_size ( const struct RecurrencePattern *  rp)
_PUBLIC_ struct SPropTagArray* set_SPropTagArray ( TALLOC_CTX *  mem_ctx,
uint32_t  PropCount,
  ... 
)
read

Create a property tag array

Parameters
mem_ctxtalloc memory context to use for allocation
PropCountthe number of properties in the array

The varargs (the third and subsequent arguments) are the property tags to make up the array. So the normal way to use this to create an array of two tags is like:

struct SPropTagArray *array

Referenced by AddUserPermission(), DuplicateProfile(), GetABRecipientInfo(), GetBestBody(), GetFolderItemsCount(), GetUserFreeBusyData(), ModifyUserPermission(), ProcessNetworkProfile(), and RemoveUserPermission().

_PUBLIC_ bool set_SPropValue_proptag ( struct SPropValue *  lpProps,
enum MAPITAGS  aulPropTag,
const void *  data 
)
_PUBLIC_ bool set_SPropValue_proptag_date_timeval ( struct SPropValue *  lpProps,
enum MAPITAGS  aulPropTag,
const struct timeval *  t 
)
_PUBLIC_ enum MAPISTATUS SPropTagArray_add ( TALLOC_CTX *  mem_ctx,
struct SPropTagArray *  SPropTagArray,
enum MAPITAGS  aulPropTag 
)

Add a property tag to an existing properties array

Parameters
mem_ctxtalloc memory context to use for allocation
SPropTagArrayexisting properties array to add to
aulPropTagthe property tag to add
Returns
MAPI_E_SUCCESS on success, otherwise MAPI error.
Note
Possible MAPI error codes are:
  • MAPI_E_NOT_INITIALIZED: MAPI subsystem has not been initialized
  • MAPI_E_INVALID_PARAMETER: SPropTagArray parameter is not correctly set

References OPENCHANGE_RETVAL_IF.

Referenced by OpenEmbeddedMessage(), OpenMessage(), and ReloadCachedInformation().

_PUBLIC_ enum MAPISTATUS SPropTagArray_delete ( TALLOC_CTX *  mem_ctx,
struct SPropTagArray *  SPropTagArray,
uint32_t  aulPropTag 
)

Delete a property tag from an existing properties array

Parameters
mem_ctxtalloc memory context to use for allocation
SPropTagArrayexisting properties array to remove from
aulPropTagthe property tag to remove
Returns
MAPI_E_SUCCESS on success, otherwise MAPI error.
Note
Possible MAPI error codes are:
  • MAPI_E_NOT_INITIALIZED: MAPI subsystem has not been initialized
  • MAPI_E_INVALID_PARAMETER: SPropTagArray parameter is not correctly set

References OPENCHANGE_RETVAL_IF.

_PUBLIC_ enum MAPISTATUS SPropTagArray_find ( struct SPropTagArray SPropTagArray  ,
enum MAPITAGS  aulPropTag,
uint32_t *  propIdx 
)

Return the index of a property tag in an existing properties array

Parameters
SPropTagArrayexisting properties array to remove from
aulPropTagthe property tag to find
propIdxthe index of the found property (undefined when MAPI_E_NOT_FOUND is returned)
Returns
MAPI_E_SUCCESS on success, otherwise MAPI error.
Note
Possible MAPI error codes are:
  • MAPI_E_NOT_INITIALIZED: MAPI subsystem has not been initialized
  • MAPI_E_INVALID_PARAMETER: SPropTagArray parameter is not correctly set

References OPENCHANGE_RETVAL_IF.

_PUBLIC_ enum MAPISTATUS SRow_addprop ( struct SRow *  aRow,
struct SPropValue  spropvalue 
)

add a SPropValue structure to a SRow array

Parameters
aRowpointer to the SRow array where spropvalue should be appended
spropvaluereference to the SPropValue structure to add to aRow
Returns
MAPI_E_SUCCESS on success, otherwise MAPI_E_INVALID_PARAMETER.

References get_SPropValue_data(), OPENCHANGE_RETVAL_IF, and set_SPropValue().

Referenced by OpenEmbeddedMessage(), OpenMessage(), ReloadCachedInformation(), and SetRecipientType().

_PUBLIC_ uint32_t SRowSet_propcpy ( TALLOC_CTX *  mem_ctx,
struct SRowSet *  SRowSet,
struct SPropValue  spropvalue 
)

Append a SPropValue structure to given SRowSet

Parameters
mem_ctxpointer to the memory context
SRowSetpointer to the SRowSet array to update
spropvaluethe SPropValue to append within SRowSet
Returns
0 on success, otherwise 1

References set_SPropValue().


Creative Commons License
Creative Commons Attribution icon Creative Commons Share Alike icon
This content is licensed under the Creative Commons
Attribution ShareAlike License v. 3.0:
http://creativecommons.org/licenses/by-sa/3.0/