/*
* Copyright (C) 2005-2010 Alfresco Software Limited.
*
* This file is part of Alfresco
*
* Alfresco is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Alfresco is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Alfresco. If not, see
* messageFrom: -- imap:messageFrom, cm:originator * messageTo: -- imap:messageTo * messageCc: -- imap:messageCc * messageSubject: -- imap:messageSubject, cm:title, cm:description, cm:subjectline * messageSent: -- imap:dateSent, cm:sentdate * All{@link Header#getName() header names}:
* Thread-Index: -- imap:threadIndex * Message-ID: -- imap:messageId * date: -- imap:dateReceived * * TIKA Note - to and cc are missing, and date stuff isn't * great. Thread index is missing, and arbitrary headers * don't seem to be supported * * @author Derek Hulley * @since 3.2 */ public class RFC822MetadataExtracter extends AbstractMappingMetadataExtracter { protected static final String KEY_MESSAGE_FROM = "messageFrom"; protected static final String KEY_MESSAGE_TO = "messageTo"; protected static final String KEY_MESSAGE_CC = "messageCc"; protected static final String KEY_MESSAGE_SUBJECT = "messageSubject"; protected static final String KEY_MESSAGE_SENT = "messageSent"; public static String[] SUPPORTED_MIMETYPES = new String[] { MimetypeMap.MIMETYPE_RFC822 }; public RFC822MetadataExtracter() { super(new HashSet(Arrays.asList(SUPPORTED_MIMETYPES))); } @Override protected Map extractRaw(ContentReader reader) throws Throwable { Map rawProperties = newRawMap(); InputStream is = null; try { is = reader.getContentInputStream(); MimeMessage mimeMessage = new MimeMessage(null, is); if (mimeMessage != null) { //Extract values that doesn't match to headers and need to be encoded. putRawValue(KEY_MESSAGE_FROM, InternetAddress.toString(mimeMessage.getFrom()), rawProperties); putRawValue(KEY_MESSAGE_TO, InternetAddress.toString(mimeMessage.getRecipients(RecipientType.TO)), rawProperties); putRawValue(KEY_MESSAGE_CC, InternetAddress.toString(mimeMessage.getRecipients(RecipientType.CC)), rawProperties); putRawValue(KEY_MESSAGE_SENT, mimeMessage.getSentDate(), rawProperties); String[] subj = mimeMessage.getHeader("Subject"); if (subj != null && subj.length > 0) { String decodedSubject = subj[0]; try { decodedSubject = MimeUtility.decodeText(decodedSubject); } catch (UnsupportedEncodingException e) { logger.warn(e.toString()); } putRawValue(KEY_MESSAGE_SUBJECT, decodedSubject, rawProperties); } //Extract values from headers Set keys = getMapping().keySet(); Enumeration headers = mimeMessage.getAllHeaders(); while (headers.hasMoreElements()) { Header header = (Header) headers.nextElement(); if (keys.contains(header.getName())) { header.getValue(); putRawValue(header.getName(), header.getValue(), rawProperties); } } } } finally { if (is != null) { try { is.close(); } catch (IOException e) { } } } // Done return rawProperties; } /** * Back door for RM * @return */ public final Map > getCurrentMapping() { return super.getMapping(); } // /** // * Back door for RM // * @return // */ // public void setMapping(Map > mapping) // { // super.setMapping(mapping); // } }