Module exchangelib.services.get_folder
Expand source code
from .common import EWSAccountService, parse_folder_elem, create_folder_ids_element, \
create_shape_element
from ..errors import ErrorFolderNotFound, ErrorNoPublicFolderReplicaAvailable, ErrorInvalidOperation
from ..util import create_element, MNS
class GetFolder(EWSAccountService):
"""MSDN: https://docs.microsoft.com/en-us/exchange/client-developer/web-service-reference/getfolder-operation"""
SERVICE_NAME = 'GetFolder'
element_container_name = '{%s}Folders' % MNS
ERRORS_TO_CATCH_IN_RESPONSE = EWSAccountService.ERRORS_TO_CATCH_IN_RESPONSE + (
ErrorFolderNotFound, ErrorNoPublicFolderReplicaAvailable, ErrorInvalidOperation,
)
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.folders = [] # A hack to communicate parsing args to _elems_to_objs()
def call(self, folders, additional_fields, shape):
"""Take a folder ID and returns the full information for that folder.
:param folders: a list of Folder objects
:param additional_fields: the extra fields that should be returned with the folder, as FieldPath objects
:param shape: The set of attributes to return
:return: XML elements for the folders, in stable order
"""
# We can't easily find the correct folder class from the returned XML. Instead, return objects with the same
# class as the folder instance it was requested with.
self.folders = list(folders) # Convert to a list, in case 'folders' is a generator. We're iterating twice.
return self._elems_to_objs(self._chunked_get_elements(
self.get_payload,
items=self.folders,
additional_fields=additional_fields,
shape=shape,
))
def _elems_to_objs(self, elems):
for folder, elem in zip(self.folders, elems):
if isinstance(elem, Exception):
yield elem
continue
yield parse_folder_elem(elem=elem, folder=folder, account=self.account)
def get_payload(self, folders, additional_fields, shape):
getfolder = create_element('m:%s' % self.SERVICE_NAME)
foldershape = create_shape_element(
tag='m:FolderShape', shape=shape, additional_fields=additional_fields, version=self.account.version
)
getfolder.append(foldershape)
folder_ids = create_folder_ids_element(tag='m:FolderIds', folders=folders, version=self.account.version)
getfolder.append(folder_ids)
return getfolder
Classes
class GetFolder (*args, **kwargs)
-
MSDN: https://docs.microsoft.com/en-us/exchange/client-developer/web-service-reference/getfolder-operation
Expand source code
class GetFolder(EWSAccountService): """MSDN: https://docs.microsoft.com/en-us/exchange/client-developer/web-service-reference/getfolder-operation""" SERVICE_NAME = 'GetFolder' element_container_name = '{%s}Folders' % MNS ERRORS_TO_CATCH_IN_RESPONSE = EWSAccountService.ERRORS_TO_CATCH_IN_RESPONSE + ( ErrorFolderNotFound, ErrorNoPublicFolderReplicaAvailable, ErrorInvalidOperation, ) def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self.folders = [] # A hack to communicate parsing args to _elems_to_objs() def call(self, folders, additional_fields, shape): """Take a folder ID and returns the full information for that folder. :param folders: a list of Folder objects :param additional_fields: the extra fields that should be returned with the folder, as FieldPath objects :param shape: The set of attributes to return :return: XML elements for the folders, in stable order """ # We can't easily find the correct folder class from the returned XML. Instead, return objects with the same # class as the folder instance it was requested with. self.folders = list(folders) # Convert to a list, in case 'folders' is a generator. We're iterating twice. return self._elems_to_objs(self._chunked_get_elements( self.get_payload, items=self.folders, additional_fields=additional_fields, shape=shape, )) def _elems_to_objs(self, elems): for folder, elem in zip(self.folders, elems): if isinstance(elem, Exception): yield elem continue yield parse_folder_elem(elem=elem, folder=folder, account=self.account) def get_payload(self, folders, additional_fields, shape): getfolder = create_element('m:%s' % self.SERVICE_NAME) foldershape = create_shape_element( tag='m:FolderShape', shape=shape, additional_fields=additional_fields, version=self.account.version ) getfolder.append(foldershape) folder_ids = create_folder_ids_element(tag='m:FolderIds', folders=folders, version=self.account.version) getfolder.append(folder_ids) return getfolder
Ancestors
Class variables
var ERRORS_TO_CATCH_IN_RESPONSE
var SERVICE_NAME
var element_container_name
Methods
def call(self, folders, additional_fields, shape)
-
Take a folder ID and returns the full information for that folder.
:param folders: a list of Folder objects :param additional_fields: the extra fields that should be returned with the folder, as FieldPath objects :param shape: The set of attributes to return
:return: XML elements for the folders, in stable order
Expand source code
def call(self, folders, additional_fields, shape): """Take a folder ID and returns the full information for that folder. :param folders: a list of Folder objects :param additional_fields: the extra fields that should be returned with the folder, as FieldPath objects :param shape: The set of attributes to return :return: XML elements for the folders, in stable order """ # We can't easily find the correct folder class from the returned XML. Instead, return objects with the same # class as the folder instance it was requested with. self.folders = list(folders) # Convert to a list, in case 'folders' is a generator. We're iterating twice. return self._elems_to_objs(self._chunked_get_elements( self.get_payload, items=self.folders, additional_fields=additional_fields, shape=shape, ))
def get_payload(self, folders, additional_fields, shape)
-
Expand source code
def get_payload(self, folders, additional_fields, shape): getfolder = create_element('m:%s' % self.SERVICE_NAME) foldershape = create_shape_element( tag='m:FolderShape', shape=shape, additional_fields=additional_fields, version=self.account.version ) getfolder.append(foldershape) folder_ids = create_folder_ids_element(tag='m:FolderIds', folders=folders, version=self.account.version) getfolder.append(folder_ids) return getfolder
Inherited members