001/*
002 * (C) Copyright 2015 Nuxeo SA (http://nuxeo.com/) and others.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 *
016 * Contributors:
017 *     Nuxeo
018 */
019
020package org.nuxeo.ecm.showcase.content;
021
022import java.io.IOException;
023import java.net.URL;
024
025import org.apache.commons.logging.Log;
026import org.apache.commons.logging.LogFactory;
027import org.nuxeo.ecm.core.api.Blob;
028import org.nuxeo.ecm.core.api.CoreSession;
029import org.nuxeo.ecm.core.api.impl.blob.URLBlob;
030import org.nuxeo.ecm.platform.content.template.service.PostContentCreationHandler;
031import org.nuxeo.runtime.api.Framework;
032
033/**
034 * @author <a href="mailto:ak@nuxeo.com">Arnaud Kervern</a>
035 * @since 7.10
036 */
037public class InitListener implements PostContentCreationHandler {
038
039    private static final Log log = LogFactory.getLog(InitListener.class);
040
041    private static final String SHOWCASE_CONTENT = "showcase_content.zip";
042
043    @Override
044    public void execute(CoreSession session) {
045        if (Framework.isTestModeSet()) {
046            return;
047        }
048
049        try {
050            URL url = getClass().getClassLoader().getResource(SHOWCASE_CONTENT);
051            if (url == null) {
052                throw new IOException("Unable to found " + SHOWCASE_CONTENT + " resource.");
053            }
054
055            Blob blob = new URLBlob(url);
056            new ShowcaseContentImporter(session).create(blob);
057            log.info("Showcase content imported.");
058        } catch (IOException e) {
059            log.error(e, e);
060        }
061    }
062}