This Subversion repository is deprecated; projects are migrated to Git.

As of April 2012, parts of this repository have migrated to Git.

Please see details and status on the following pages:

All contents from this repository will remain available.

All migrated projects (and only migrated projects) will be switched to a read-only mode, and will not be maintained on Subversion any further.

Nothing changes for projects which do not get migrated.

If you would like a particular project to be migrated, please contact gregory dot joseph at magnolia-cms dot com.

/[main]/community/modules/magnolia-module-data/trunk/src/main/java/info/magnolia/module/data/commands/ImportCommand.java

Contents of /community/modules/magnolia-module-data/trunk/src/main/java/info/magnolia/module/data/commands/ImportCommand.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 50643 - (show annotations) (download)
Wed Nov 2 06:28:59 2011 UTC (6 months, 2 weeks ago) by dlipp
File size: 4062 byte(s)
QA: added missing @override's
1 /**
2 * This file Copyright (c) 2003-2011 Magnolia International
3 * Ltd. (http://www.magnolia-cms.com). All rights reserved.
4 *
5 *
6 * This file is dual-licensed under both the Magnolia
7 * Network Agreement and the GNU General Public License.
8 * You may elect to use one or the other of these licenses.
9 *
10 * This file is distributed in the hope that it will be
11 * useful, but AS-IS and WITHOUT ANY WARRANTY; without even the
12 * implied warranty of MERCHANTABILITY or FITNESS FOR A
13 * PARTICULAR PURPOSE, TITLE, or NONINFRINGEMENT.
14 * Redistribution, except as permitted by whichever of the GPL
15 * or MNA you select, is prohibited.
16 *
17 * 1. For the GPL license (GPL), you can redistribute and/or
18 * modify this file under the terms of the GNU General
19 * Public License, Version 3, as published by the Free Software
20 * Foundation. You should have received a copy of the GNU
21 * General Public License, Version 3 along with this program;
22 * if not, write to the Free Software Foundation, Inc., 51
23 * Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
24 *
25 * 2. For the Magnolia Network Agreement (MNA), this file
26 * and the accompanying materials are made available under the
27 * terms of the MNA which accompanies this distribution, and
28 * is available at http://www.magnolia-cms.com/mna.html
29 *
30 * Any modifications to this file must keep this entire header
31 * intact.
32 *
33 */
34 package info.magnolia.module.data.commands;
35
36 import info.magnolia.cms.util.AlertUtil;
37 import info.magnolia.commands.MgnlCommand;
38 import info.magnolia.context.Context;
39 import info.magnolia.context.WebContext;
40 import info.magnolia.module.data.DataModule;
41 import info.magnolia.module.data.importer.ImportException;
42 import info.magnolia.module.data.importer.ImportHandler;
43
44 import org.apache.commons.lang.StringUtils;
45 import org.slf4j.Logger;
46 import org.slf4j.LoggerFactory;
47
48
49 /**
50 * This command starts the specified importer.
51 *
52 * @version $Revision$ ($Author$)
53 *
54 */
55 public class ImportCommand extends MgnlCommand {
56
57 private static final Logger log = LoggerFactory.getLogger(ImportCommand.class);
58
59 public static final String NODE_DATA_IMPORTER_NAME = "importer";
60
61 protected String importer;
62
63 /**
64 * This method retrieves the importer for the configured name and executes it.
65 *
66 * @see org.apache.commons.chain.Command#execute(org.apache.commons.chain.Context)
67 */
68 @Override
69 public boolean execute(Context ctx) {
70 String importerName = getImporter();
71 ImportHandler handler = DataModule.getInstance().getImporter(importerName);
72 if(handler == null && ctx instanceof WebContext){
73 importerName = StringUtils.stripStart(((info.magnolia.context.WebContext) ctx).getRequest().getParameter("path"), "/");
74 handler = DataModule.getInstance().getImporter(importerName);
75 }
76 if(handler == null){
77 log.error("No import handler with name [" + importerName +"] found.");
78 AlertUtil.setMessage(ctx.getMessages("info.magnolia.module.data.messages").get("module.data.command.type.import.error.nohandler", new Object[]{importerName}));
79 return false;
80 }
81
82 try {
83 handler.execute();
84 return true;
85 } catch (ImportException e) {
86 log.error("exception during importing", e);
87 AlertUtil.setMessage(ctx.getMessages("info.magnolia.module.data.messages").get("module.data.command.type.import.error.import"), e);
88
89 return false;
90 }
91 }
92
93 public String getImporter(){
94 if(importer == null){
95 log.warn("The import command should define an importer in a property named by [" + NODE_DATA_IMPORTER_NAME + "]");
96 return "";
97 }
98 return importer;
99 }
100
101 public void setImporter(String importer) {
102 this.importer = importer;
103 }
104
105 @Override
106 public void release() {
107 super.release();
108 this.importer = null;
109 }
110 }

Please contact the developer's list in case of issues or questions.

ViewVC Help
Powered by ViewVC 1.1.13