本文整理匯總了Python中OFS.interfaces.IObjectWillBeAddedEvent.providedBy方法的典型用法代碼示例。如果您正苦於以下問題:Python IObjectWillBeAddedEvent.providedBy方法的具體用法?Python IObjectWillBeAddedEvent.providedBy怎麽用?Python IObjectWillBeAddedEvent.providedBy使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類OFS.interfaces.IObjectWillBeAddedEvent
的用法示例。
在下文中一共展示了IObjectWillBeAddedEvent.providedBy方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: remove_ghosts
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def remove_ghosts(obj, event):
"""We are going to remove a object: we need to check if its neutral
and remove their indexes also.
"""
if not IObjectWillBeAddedEvent.providedBy(event) \
and (IObjectWillBeMovedEvent.providedBy(event)
or IObjectWillBeRemovedEvent.providedBy(event)):
if not is_shared_original(obj):
return
content_id = IUUID(obj).split('-')[0]
site = getSite()
try:
pc = getToolByName(site, 'portal_catalog')
except AttributeError:
# In case we are removing the site there is no portal_catalog
return
language_tool = getToolByName(site, 'portal_languages')
language_infos = language_tool.supported_langs
for language_info in language_infos:
brains = pc.unrestrictedSearchResults(
UID=content_id + '-' + language_info)
for brain in brains:
obj.unrestrictedTraverse(brain.getPath()).unindexObject()
brains = pc.unrestrictedSearchResults(
UID=content_id)
for brain in brains:
obj.unrestrictedTraverse(brain.getPath()).unindexObject()
if IActionSucceededEvent.providedBy(event):
reindex_neutral(obj, event)
示例2: onTreeSpanningComponentBeforeDelete
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def onTreeSpanningComponentBeforeDelete(ob, event):
"""
When a component that links a device to another tree is going to
be removed, update the device's paths.
"""
if not IObjectWillBeAddedEvent.providedBy(event):
component = ob
try:
catalog = ob.getPhysicalRoot().zport.global_catalog
except (KeyError, AttributeError):
# Migrate script hasn't run yet; ignore indexing
return
device = component.device()
if not device:
# OS relation has already been broken; get by path
path = component.getPrimaryPath()
try:
devpath = path[:path.index('devices')+2]
device = component.unrestrictedTraverse(devpath)
except ValueError:
# We've done our best. Give up.
return
if device:
oldpaths = devicePathsFromComponent(component)
catalog.unindex_object_from_paths(device, oldpaths)
示例3: onDeviceDeleted
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def onDeviceDeleted(object, event):
# Clean up any AMQP queues we may have created for this device.
if not IObjectWillBeAddedEvent.providedBy(event):
connectionInfo = getUtility(IAMQPConnectionInfo)
queueSchema = getUtility(IQueueSchema)
# For some reason, if an error gets thrown by queue_delete, it seems
# to break the connection, so we'll just use a separate connection
# for each call to it.
for queue in ('$OpenStackInboundEvent', '$OpenStackInboundPerf'):
queueName = substitute_replacements(queueSchema._queue_nodes[queue].name,
{'device': object.id})
amqpClient = BlockingPublisher(connectionInfo, queueSchema)
channel = amqpClient.getChannel()
try:
LOG.debug("Removing AMQP queue %s" % queueName)
channel.queue_delete(queueName)
LOG.info("Removed AMQP queue %s successfully." % queueName)
except AMQPChannelException, e:
# if the queue doesn't exist, don't worry about it.
if e.amqp_reply_code == 404:
LOG.debug('Queue %s did not exist', queueName)
else:
LOG.exception(e)
amqpClient.close()
示例4: handle_topic_deletion
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def handle_topic_deletion(ob, event):
"""The ForumTopic will be moved/removed"""
if not IObjectWillBeAddedEvent.providedBy(event):
# Object will be removed:
# Same as above. If the topic is deleted by mistake the statistics
#should still be there in case of undo.
#ob.aq_inner.aq_parent.removeTopicHits(ob.id)
pass
示例5: onOrganizerBeforeDelete
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def onOrganizerBeforeDelete(ob, event):
"""
Before we delete the organizer we need to remove its references
to the devices.
"""
if not IObjectWillBeAddedEvent.providedBy(event):
for device in ob.devices.objectValuesGen():
notify(IndexingEvent(device, idxs='path', triggered_by_zope_event=True))
示例6: content_removed
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def content_removed(content, event):
if (event.object != content or
IObjectWillBeAddedEvent.providedBy(event) or
event.newParent == event.oldParent):
return
if IOrderableContainer.providedBy(event.oldParent):
manager = IOrderManager(event.oldParent)
manager.remove(content)
示例7: onObjectRemoved
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def onObjectRemoved(ob, event):
"""
Unindex, please.
"""
if not IObjectWillBeAddedEvent.providedBy(event):
object_to_unindex = _get_object_to_index(ob)
if object_to_unindex:
getUtility(IModelCatalog).uncatalog_object(object_to_unindex)
示例8: onInterfaceRemoved
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def onInterfaceRemoved(ob, event):
"""
Unindex
"""
if not IObjectWillBeAddedEvent.providedBy(event):
macs = ob.device().getMacAddressCache()
if ob.macaddress in macs:
macs.remove(ob.macaddress)
示例9: unindexBeforeDelete
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def unindexBeforeDelete(ob, event):
"""
Multisubscriber for IIndexed + IObjectWillBeMovedEvent
"""
if not IObjectWillBeAddedEvent.providedBy(event):
if isinstance(ob, IpInterface):
beforeDeleteIpInterface(ob, event)
else:
ob.unindex_object()
示例10: handle_forum_deletion
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def handle_forum_deletion(ob, event):
"""The Forum will be moved/removed"""
if not IObjectWillBeAddedEvent.providedBy(event):
# Object will be removed:
#Statistics db should not be removed.
#If forum is undeleted then the statistics should still be there.
#ob._removeStatisticsContainer()
pass
示例11: related_change_on_moving
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def related_change_on_moving(obj, event):
""" Set local roles on related objects before moving """
if IObjectWillBeAddedEvent.providedBy(event) or IObjectWillBeRemovedEvent.providedBy(event): # not move
return
if event.oldParent and event.newParent and event.oldParent == event.newParent: # rename
return
(fti_config, fti) = fti_configuration(obj)
if 'static_config' not in fti_config:
return
related_role_removal(obj, get_state(obj), fti_config)
示例12: test_events
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def test_events(self):
from OFS.interfaces import IObjectWillBeAddedEvent
from zope.component import adapter
from zope.component import provideHandler
from zope.container.interfaces import IContainerModifiedEvent
from zope.container.interfaces import IObjectAddedEvent
from zope.lifecycleevent.interfaces import IObjectCreatedEvent
events = []
@adapter(IObjectCreatedEvent)
def _handleObjectCreated(event):
events.append(event)
provideHandler(_handleObjectCreated)
@adapter(IObjectWillBeAddedEvent)
def _handleObjectWillBeAdded(event):
events.append(event)
provideHandler(_handleObjectWillBeAdded)
@adapter(IObjectAddedEvent)
def _handleObjectAdded(event):
events.append(event)
provideHandler(_handleObjectAdded)
@adapter(IContainerModifiedEvent)
def _handleContainerModified(event):
events.append(event)
provideHandler(_handleContainerModified)
self.ti.constructInstance(self.f, 'foo')
self.assertEquals(len(events), 4)
evt = events[0]
self.failUnless(IObjectCreatedEvent.providedBy(evt))
self.assertEquals(evt.object, self.f.foo)
evt = events[1]
self.failUnless(IObjectWillBeAddedEvent.providedBy(evt))
self.assertEquals(evt.object, self.f.foo)
self.assertEquals(evt.oldParent, None)
self.assertEquals(evt.oldName, None)
self.assertEquals(evt.newParent, self.f)
self.assertEquals(evt.newName, 'foo')
evt = events[2]
self.failUnless(IObjectAddedEvent.providedBy(evt))
self.assertEquals(evt.object, self.f.foo)
self.assertEquals(evt.oldParent, None)
self.assertEquals(evt.oldName, None)
self.assertEquals(evt.newParent, self.f)
self.assertEquals(evt.newName, 'foo')
evt = events[3]
self.failUnless(IContainerModifiedEvent.providedBy(evt))
self.assertEquals(evt.object, self.f)
示例13: onComponentRemoved
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def onComponentRemoved(ob, event):
if not IObjectWillBeAddedEvent.providedBy(event):
spec = get_component_field_spec(ob.meta_type)
if spec is None:
return
catalog = spec.get_catalog(ob, ob.meta_type)
uid = '/'.join(ob.getPrimaryPath())
if catalog.getrid(uid) is None:
# Avoid "tried to uncatalog nonexistent object" warnings
return
catalog.uncatalog_object(uid)
示例14: onDeviceDeleted
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def onDeviceDeleted(object, event):
'''
Clean up the dangling reference to a device if that device has been removed.
(Note: we may re-create the device automatically next time someone calls
self.ensure_proxy_device, though)
'''
if not IObjectWillBeAddedEvent.providedBy(event) and not IObjectWillBeMovedEvent.providedBy(event):
if hasattr(object, 'openstackProxyComponentUUID'):
component = GUIDManager(object.dmd).getObject(getattr(object, 'openstackProxyComponentUUID', None))
if component:
component.release_proxy_device()
object.openstackProxyComponentUUID = None
示例15: related_change_on_moving
# 需要導入模塊: from OFS.interfaces import IObjectWillBeAddedEvent [as 別名]
# 或者: from OFS.interfaces.IObjectWillBeAddedEvent import providedBy [as 別名]
def related_change_on_moving(obj, event):
""" Set local roles on related objects before moving """
if IObjectWillBeAddedEvent.providedBy(event) or IObjectWillBeRemovedEvent.providedBy(event): # not move
return
if event.oldParent and event.newParent and event.oldParent == event.newParent: # rename
return
(fti_config, fti) = fti_configuration(obj)
if not fti_config:
return
for (name, f) in get_localrole_fields(fti):
if name not in fti_config:
continue
related_role_removal(obj, get_state(obj), fti_config[name], name)