org.obm.imap.archive.DatabaseOperations.java Source code

Java tutorial

Introduction

Here is the source code for org.obm.imap.archive.DatabaseOperations.java

Source

/* ***** BEGIN LICENSE BLOCK *****
 * Copyright (C) 2014  Linagora
 * 
 * This program is free software: you can redistribute it and/or modify it under
 * the terms of the GNU Affero General Public License as published by the Free
 * Software Foundation, either version 3 of the License, or (at your option) any
 * later version, provided you comply with the Additional Terms applicable for OBM
 * software by Linagora pursuant to Section 7 of the GNU Affero General Public
 * License, subsections (b), (c), and (e), pursuant to which you must notably (i)
 * retain the displaying by the interactive user interfaces of the OBM, Free
 * Communication by Linagora? Logo with the You are using the Open Source and
 * free version of OBM developed and supported by Linagora. Contribute to OBM R&D
 * by subscribing to an Enterprise offer !? infobox, (ii) retain all hypertext
 * links between OBM and obm.org, between Linagora and linagora.com, as well as
 * between the expression Enterprise offer? and pro.obm.org, and (iii) refrain
 * from infringing Linagora intellectual property rights over its trademarks and
 * commercial brands. Other Additional Terms apply, see
 * <http://www.linagora.com/licenses/> for more details.
 * 
 * This program 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 Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License and
 * its applicable Additional Terms for OBM along with this program. If not, see
 * <http://www.gnu.org/licenses/> for the GNU Affero General   Public License
 * version 3 and <http://www.linagora.com/licenses/> for the Additional Terms
 * applicable to the OBM software.
 * ***** END LICENSE BLOCK ***** */

package org.obm.imap.archive;

import org.joda.time.DateTime;
import org.obm.imap.archive.beans.ArchiveStatus;
import org.obm.imap.archive.beans.ArchiveTreatmentRunId;
import org.obm.imap.archive.beans.ConfigurationState;
import org.obm.imap.archive.beans.RepeatKind;
import org.obm.imap.archive.dao.DomainConfigurationJdbcImpl;
import org.obm.imap.archive.dao.ImapFolderJdbcImpl;
import org.obm.imap.archive.dao.ProcessedFolderJdbcImpl;
import org.obm.imap.archive.dao.SqlTables;
import org.obm.imap.archive.dao.SqlTables.MailArchiveRun;

import com.ninja_squad.dbsetup.Operations;
import com.ninja_squad.dbsetup.operation.Insert;
import com.ninja_squad.dbsetup.operation.Operation;

import fr.aliacom.obm.common.domain.ObmDomainUuid;

public class DatabaseOperations {

    public static Operation cleanDB() {
        return Operations.sequenceOf(Operations.deleteAllFrom(DomainConfigurationJdbcImpl.TABLE.NAME),
                Operations.deleteAllFrom(DomainConfigurationJdbcImpl.SCOPE_USERS.TABLE.NAME),
                Operations.deleteAllFrom(DomainConfigurationJdbcImpl.MAILING.TABLE.NAME),
                Operations.deleteAllFrom(SqlTables.MailArchiveRun.NAME),
                Operations.deleteAllFrom(SqlTables.MailArchiveRun.NAME),
                Operations.deleteAllFrom(ProcessedFolderJdbcImpl.TABLE.NAME),
                Operations.deleteAllFrom(ImapFolderJdbcImpl.TABLE.NAME));
    }

    public static Insert insertDomainConfiguration(ObmDomainUuid domainId, ConfigurationState state) {
        return Operations.insertInto(DomainConfigurationJdbcImpl.TABLE.NAME)
                .columns(DomainConfigurationJdbcImpl.TABLE.FIELDS.DOMAIN_UUID,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.ACTIVATED,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.REPEAT_KIND,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.DAY_OF_WEEK,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.DAY_OF_MONTH,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.DAY_OF_YEAR,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.HOUR,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.MINUTE,
                        DomainConfigurationJdbcImpl.TABLE.FIELDS.ARCHIVE_MAIN_FOLDER)
                .values(domainId.get(), ConfigurationState.ENABLE == state ? true : false, RepeatKind.DAILY, 2, 10,
                        355, 10, 32, "arChive")
                .build();
    }

    public static Insert insertArchiveTreatment(ArchiveTreatmentRunId runId, ObmDomainUuid domainId) {
        return Operations.insertInto(MailArchiveRun.NAME)
                .columns(MailArchiveRun.Fields.UUID, MailArchiveRun.Fields.DOMAIN_UUID,
                        MailArchiveRun.Fields.STATUS, MailArchiveRun.Fields.SCHEDULE, MailArchiveRun.Fields.START,
                        MailArchiveRun.Fields.END, MailArchiveRun.Fields.HIGHER_BOUNDARY,
                        MailArchiveRun.Fields.RECURRENT)
                .values(runId.serialize(), domainId.get(), ArchiveStatus.SUCCESS,
                        DateTime.parse("2014-06-01T00:00:00.000Z").toDate(),
                        DateTime.parse("2014-06-01T00:01:00.000Z").toDate(),
                        DateTime.parse("2014-06-01T00:02:00.000Z").toDate(),
                        DateTime.parse("2014-06-01T00:03:00.000Z").toDate(), true)
                .build();
    }
}