def _publish(self, envelopData): if isinstance(envelopData, unicode): envelopeData = json.loads(envelopData) result = {self.__OK: True} try: # Set the envelop data timestaps. timeStamp = h.nowToISO8601Zformat() for stamp in ResourceDataModel._TIME_STAMPS: envelopData[stamp] = timeStamp resourceData = ResourceDataModel(envelopData) #Check if the envelop get filtered out isFilteredOut, reason = self._isResourceDataFilteredOut( resourceData) if isFilteredOut: result[self.__ERROR] = reason else: resourceData.publishing_node = LRNode.nodeDescription.node_id resourceData.save() result[resourceData._DOC_ID] = resourceData.doc_ID except SpecValidationException as ex: log.exception(ex) result[self.__ERROR] = "\n" + pprint.pformat(str(ex), indent=4) except Exception as ex: log.exception(ex) result[self.__ERROR] = "internal error" if result.has_key(self.__ERROR): result[self.__OK] = False return result