Source code for azure.eventhub.aio.eventprocessor.partition_context

# --------------------------------------------------------------------------------------------
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License. See License.txt in the project root for license information.
# -----------------------------------------------------------------------------------


from .partition_manager import PartitionManager


[docs]class PartitionContext(object): """Contains partition related context information for a PartitionProcessor instance to use. Users can use update_checkpoint() of this class to save checkpoint data. """ def __init__(self, eventhub_name: str, consumer_group_name: str, partition_id: str, owner_id: str, partition_manager: PartitionManager): self.partition_id = partition_id self.eventhub_name = eventhub_name self.consumer_group_name = consumer_group_name self.owner_id = owner_id self._partition_manager = partition_manager
[docs] async def update_checkpoint(self, offset, sequence_number=None): """ Updates the checkpoint using the given information for the associated partition and consumer group in the chosen storage service. :param offset: The offset of the ~azure.eventhub.EventData the new checkpoint will be associated with. :type offset: str :param sequence_number: The sequence_number of the ~azure.eventhub.EventData the new checkpoint will be associated with. :type sequence_number: int :return: None """ # TODO: whether change this method to accept event_data as well await self._partition_manager.update_checkpoint( self.eventhub_name, self.consumer_group_name, self.partition_id, self.owner_id, offset, sequence_number )