📄 cmsrestoreresource.java
字号:
/*
* File : $Source: /usr/local/cvs/opencms/src-modules/com/opencms/workplace/CmsRestoreResource.java,v $
* Date : $Date: 2005/06/27 23:22:07 $
* Version: $Revision: 1.4 $
*
* This library is part of OpenCms -
* the Open Source Content Mananagement System
*
* Copyright (C) 2001 The OpenCms Group
*
* This library 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 2.1 of the License, or (at your option) any later version.
*
* This library 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.
*
* For further information about OpenCms, please see the
* OpenCms Website: http://www.opencms.org
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package com.opencms.workplace;
import org.opencms.file.CmsObject;
import org.opencms.file.CmsResource;
import org.opencms.file.CmsResourceFilter;
import org.opencms.main.CmsException;
import org.opencms.main.OpenCms;
import org.opencms.util.CmsDateUtil;
import com.opencms.core.I_CmsSession;
import com.opencms.legacy.CmsLegacyException;
import com.opencms.legacy.CmsXmlTemplateLoader;
import java.util.Hashtable;
/**
* Template class for displaying the restore resource screen of the OpenCms workplace.<P>
* Reads template files of the content type <code>CmsXmlWpTemplateFile</code>.
*
* @author Edna Falkenhan
* @version $Revision: 1.4 $ $Date: 2005/06/27 23:22:07 $
*
* @deprecated Will not be supported past the OpenCms 6 release.
*/
public class CmsRestoreResource extends CmsWorkplaceDefault {
/**
* Overwrites the getContent method of the CmsWorkplaceDefault.<br>
* Gets the content of the undelete template and processed the data input.
* @param cms The CmsObject.
* @param templateFile The undelete template file
* @param elementName not used
* @param parameters Parameters of the request and the template.
* @param templateSelector Selector of the template tag to be displayed.
* @return Bytearre containgine the processed data of the template.
* @throws CmsException if something goes wrong.
*/
public byte[] getContent(CmsObject cms, String templateFile, String elementName,
Hashtable parameters, String templateSelector) throws CmsException {
I_CmsSession session = CmsXmlTemplateLoader.getSession(cms.getRequestContext(), true);
CmsXmlWpTemplateFile xmlTemplateDocument = new CmsXmlWpTemplateFile(cms, templateFile);
// the template to be displayed
String template = null;
// clear session values on first load
String initial = (String)parameters.get(CmsWorkplaceDefault.C_PARA_INITIAL);
if (initial != null) {
// remove all session values
session.removeValue(CmsWorkplaceDefault.C_PARA_RESOURCE);
//session.removeValue("versionid");
session.removeValue("restore");
session.removeValue("lasturl");
}
// get the lasturl parameter
String lasturl = getLastUrl(cms, parameters);
String restore = (String)parameters.get("restore");
if (restore != null) {
session.putValue("restore", restore);
}
restore = (String)session.getValue("restore");
String filename = (String)parameters.get(CmsWorkplaceDefault.C_PARA_RESOURCE);
if (filename != null) {
session.putValue(CmsWorkplaceDefault.C_PARA_RESOURCE, filename);
}
filename = (String)session.getValue(CmsWorkplaceDefault.C_PARA_RESOURCE);
String version = (String)session.getValue("version");
String action = (String)parameters.get("action");
CmsResource file = null;
if (filename.endsWith("/")) {
file = cms.readFolder(filename, CmsResourceFilter.IGNORE_EXPIRATION);
} else {
file = cms.readResource(filename, CmsResourceFilter.IGNORE_EXPIRATION);
}
//check if the name parameter was included in the request
// if not, the restoreresource page is shown for the first time
if (restore != null) {
if (action != null) {
// restore the resource
try {
// check the autolock resource setting and lock the resource if necessary
if (OpenCms.getWorkplaceManager().autoLockResources()) {
if (cms.getLock(filename).isNullLock()) {
// resource is not locked, lock it automatically
cms.lockResource(filename);
}
}
cms.restoreResourceBackup(cms.getSitePath(file), Integer.parseInt(version));
session.removeValue(CmsWorkplaceDefault.C_PARA_RESOURCE);
//template = "done";
// return to filelist
try {
if (lasturl == null || "".equals(lasturl)) {
CmsXmlTemplateLoader.getResponse(cms.getRequestContext()).sendCmsRedirect(getConfigFile(cms).getWorkplaceActionPath()
+ CmsWorkplaceAction.getExplorerFileUri(CmsXmlTemplateLoader.getRequest(cms.getRequestContext()).getOriginalRequest()));
} else {
CmsXmlTemplateLoader.getResponse(cms.getRequestContext()).sendRedirect(lasturl);
}
} catch (Exception e) {
throw new CmsLegacyException("Redirect fails :"
+ getConfigFile(cms).getWorkplaceActionPath()
+ CmsWorkplaceAction.getExplorerFileUri(CmsXmlTemplateLoader.getRequest(cms.getRequestContext()).getOriginalRequest()), e);
}
return null;
} catch (CmsException e) {
session.removeValue(CmsWorkplaceDefault.C_PARA_RESOURCE);
xmlTemplateDocument.setData("details", CmsException.getStackTraceAsString(e));
xmlTemplateDocument.setData("lasturl", lasturl);
return startProcessing(cms, xmlTemplateDocument, "", parameters, "error");
}
} else {
template = "wait";
}
}
// set the required datablocks
if (action == null) {
xmlTemplateDocument.setData("CHANGEDATE", CmsDateUtil.getDateTimeShort(file.getDateLastModified()));
xmlTemplateDocument.setData("USER", cms.readUser(file.getUserLastModified()).getName());
xmlTemplateDocument.setData("FILENAME", file.getName());
}
// process the selected template
return startProcessing(cms, xmlTemplateDocument, "", parameters, template);
}
/**
* Indicates if the results of this class are cacheable.
*
* @param cms CmsObject Object for accessing system resources
* @param templateFile Filename of the template file
* @param elementName Element name of this template in our parent template.
* @param parameters Hashtable with all template class parameters.
* @param templateSelector template section that should be processed.
* @return <EM>true</EM> if cacheable, <EM>false</EM> otherwise.
*/
public boolean isCacheable(CmsObject cms, String templateFile, String elementName,
Hashtable parameters, String templateSelector) {
return false;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -