def getMsgRaw(fileName, rs): msgID = rs.getLong(1) size = rs.getInt(2) storageLocation = StoredMessage.stripOldStorageDir(rs.getString(3)) custID = rs.getInt(4) ts = rs.getTimestamp(5) receivedDate = None if ts is not None: receivedDate = Date(ts.getTime) msg = StoredMessage(custID, msgID, storageLocation, None, None, receivedDate, 0, 0, 0, 0, None, amPartId, size, size, None, None) if msg: # do some validation if long(msgId) != msg.getMessageId(): printQueue.append("consumer: ERROR: message ID " + str(msgId) + " not the same as " + str(msg.getMessageId())) #print "found message", msgId, "in DB for AM partition" msgStream = msg.getEncryptedCompressedContentStream() if msgStream: out = FileOutputStream(fileName) FileUtils.copyStream(msg.getEncryptedCompressedContentStream(), out) out.flush() out.close() #print "found message", msgId, "on disk in AM partition" return True else: printErrorToRemigrate(msgId, " not found on disk for AM partition.") return False else: printErrorToRemigrate(msgId, " not found in db for AM partition.") return False
def getMsgRaw(fileName, thisMsg, threadName): printQueue.add("debug("+ threadName +"): entering getMsgRaw() with thisMsg = " + str(thisMsg.getMessageId())) msgStream = None try: msgStream = thisMsg.getEncryptedCompressedContentStream() except: pass if msgStream is not None: try: printQueue.add("debug("+ threadName +"): processing stream with thisMsg = " + str(thisMsg.getMessageId())) out = FileOutputStream(fileName) FileUtils.copyStream(msgStream, out) out.flush() out.close() printQueue.add("debug("+ threadName +"): done processing stream with thisMsg = " + str(thisMsg.getMessageId())) return True except: printErrorToRemigrate(str(thisMsg.getMessageId()), " error reading file on AM partition.") return False else: printErrorToRemigrate(str(thisMsg.getMessageId()), " not found on disk for AM partition.") return False