001/****************************************************************
002 * Licensed to the Apache Software Foundation (ASF) under one   *
003 * or more contributor license agreements.  See the NOTICE file *
004 * distributed with this work for additional information        *
005 * regarding copyright ownership.  The ASF licenses this file   *
006 * to you under the Apache License, Version 2.0 (the            *
007 * "License"); you may not use this file except in compliance   *
008 * with the License.  You may obtain a copy of the License at   *
009 *                                                              *
010 *   http://www.apache.org/licenses/LICENSE-2.0                 *
011 *                                                              *
012 * Unless required by applicable law or agreed to in writing,   *
013 * software distributed under the License is distributed on an  *
014 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY       *
015 * KIND, either express or implied.  See the License for the    *
016 * specific language governing permissions and limitations      *
017 * under the License.                                           *
018 ****************************************************************/
019package org.apache.james.mailbox.jpa.migrator.command;
020
021import javax.persistence.EntityManager;
022
023import org.apache.james.mailbox.jpa.migrator.exception.JpaMigrateException;
024
025/**
026 * JIRA IMAP-172 is "Cleanup JPAMailbox".
027 * 
028 * Simply drop the MAILBOX.MESSAGECOUNT and MAILBOX.SIZE columns.
029 * 
030 * @link https://issues.apache.org/jira/browse/IMAP-172
031 * 
032 */
033public class IMAP172JpaMigrateCommand implements JpaMigrateCommand {
034
035    /**
036     * @see org.apache.james.mailbox.jpa.migrator.command#migrate(javax.persistence.EntityManager)
037     */
038    public void migrate(EntityManager em) throws JpaMigrateException {
039        JpaMigrateQuery.executeUpdate(em, "ALTER TABLE MAILBOX DROP COLUMN MESSAGECOUNT");
040        JpaMigrateQuery.executeUpdate(em, "ALTER TABLE MAILBOX DROP COLUMN SIZE");
041    }
042
043}