|
@@ -27,6 +27,9 @@ import java.io.OutputStreamWriter;
|
|
|
import java.io.Reader;
|
|
|
import java.io.Writer;
|
|
|
import java.time.LocalDateTime;
|
|
|
+import java.util.HashMap;
|
|
|
+import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
|
import javax.servlet.http.HttpServletResponse;
|
|
@@ -37,26 +40,32 @@ import org.apache.commons.logging.LogFactory;
|
|
|
import org.codelibs.core.util.DynamicProperties;
|
|
|
import org.codelibs.fess.Constants;
|
|
|
import org.codelibs.fess.FessSystemException;
|
|
|
+import org.codelibs.fess.action.base.FessAdminAction;
|
|
|
import org.codelibs.fess.beans.FessBeans;
|
|
|
import org.codelibs.fess.crud.CommonConstants;
|
|
|
import org.codelibs.fess.crud.CrudMessageException;
|
|
|
-import org.codelibs.fess.crud.action.admin.BsSuggestElevateWordAction;
|
|
|
import org.codelibs.fess.crud.util.SAStrutsUtil;
|
|
|
import org.codelibs.fess.db.exentity.SuggestElevateWord;
|
|
|
+import org.codelibs.fess.form.admin.SuggestElevateWordForm;
|
|
|
import org.codelibs.fess.helper.SuggestHelper;
|
|
|
import org.codelibs.fess.helper.SystemHelper;
|
|
|
+import org.codelibs.fess.pager.SuggestElevateWordPager;
|
|
|
+import org.codelibs.fess.service.SuggestElevateWordService;
|
|
|
import org.codelibs.robot.util.StreamUtil;
|
|
|
import org.codelibs.sastruts.core.annotation.Token;
|
|
|
import org.codelibs.sastruts.core.exception.SSCActionMessagesException;
|
|
|
+import org.seasar.framework.beans.util.Beans;
|
|
|
+import org.seasar.framework.util.StringUtil;
|
|
|
+import org.seasar.struts.annotation.ActionForm;
|
|
|
import org.seasar.struts.annotation.Execute;
|
|
|
import org.seasar.struts.exception.ActionMessagesException;
|
|
|
import org.seasar.struts.util.ResponseUtil;
|
|
|
+import org.slf4j.Logger;
|
|
|
+import org.slf4j.LoggerFactory;
|
|
|
|
|
|
-public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
+public class SuggestElevateWordAction extends FessAdminAction {
|
|
|
|
|
|
- private static final long serialVersionUID = 1L;
|
|
|
-
|
|
|
- private static final Log log = LogFactory.getLog(SuggestElevateWordAction.class);
|
|
|
+ private static final Logger logger = LoggerFactory.getLogger(SuggestElevateWordAction.class);
|
|
|
|
|
|
@Resource
|
|
|
protected SystemHelper systemHelper;
|
|
@@ -67,11 +76,178 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
@Resource
|
|
|
protected DynamicProperties crawlerProperties;
|
|
|
|
|
|
+ // for list
|
|
|
+
|
|
|
+ public List<SuggestElevateWord> suggestElevateWordItems;
|
|
|
+
|
|
|
+ // for edit/confirm/delete
|
|
|
+
|
|
|
+ @ActionForm
|
|
|
+ @Resource
|
|
|
+ protected SuggestElevateWordForm suggestElevateWordForm;
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ protected SuggestElevateWordService suggestElevateWordService;
|
|
|
+
|
|
|
+ @Resource
|
|
|
+ protected SuggestElevateWordPager suggestElevateWordPager;
|
|
|
+
|
|
|
+ protected String displayList(final boolean redirect) {
|
|
|
+ // page navi
|
|
|
+ suggestElevateWordItems = suggestElevateWordService.getSuggestElevateWordList(suggestElevateWordPager);
|
|
|
+
|
|
|
+ // restore from pager
|
|
|
+ Beans.copy(suggestElevateWordPager, suggestElevateWordForm.searchParams).excludes(CommonConstants.PAGER_CONVERSION_RULE)
|
|
|
+
|
|
|
+ .execute();
|
|
|
+
|
|
|
+ if (redirect) {
|
|
|
+ return "index?redirect=true";
|
|
|
+ } else {
|
|
|
+ return "index.jsp";
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String index() {
|
|
|
+ return displayList(false);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Execute(validator = false, input = "error.jsp", urlPattern = "list/{pageNumber}")
|
|
|
+ public String list() {
|
|
|
+ // page navi
|
|
|
+ if (StringUtil.isNotBlank(suggestElevateWordForm.pageNumber)) {
|
|
|
+ try {
|
|
|
+ suggestElevateWordPager.setCurrentPageNumber(Integer.parseInt(suggestElevateWordForm.pageNumber));
|
|
|
+ } catch (final NumberFormatException e) {
|
|
|
+ if (logger.isDebugEnabled()) {
|
|
|
+ logger.debug("Invalid value: " + suggestElevateWordForm.pageNumber, e);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ return displayList(false);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String search() {
|
|
|
+ Beans.copy(suggestElevateWordForm.searchParams, suggestElevateWordPager).excludes(CommonConstants.PAGER_CONVERSION_RULE)
|
|
|
+
|
|
|
+ .execute();
|
|
|
+
|
|
|
+ return displayList(false);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String reset() {
|
|
|
+ suggestElevateWordPager.clear();
|
|
|
+
|
|
|
+ return displayList(false);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String back() {
|
|
|
+ return displayList(false);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = true, validate = false)
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String editagain() {
|
|
|
+ return "edit.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Execute(validator = false, input = "error.jsp", urlPattern = "confirmpage/{crudMode}/{id}")
|
|
|
+ public String confirmpage() {
|
|
|
+ if (suggestElevateWordForm.crudMode != CommonConstants.CONFIRM_MODE) {
|
|
|
+ throw new ActionMessagesException("errors.crud_invalid_mode", new Object[] { CommonConstants.CONFIRM_MODE,
|
|
|
+ suggestElevateWordForm.crudMode });
|
|
|
+ }
|
|
|
+
|
|
|
+ loadSuggestElevateWord();
|
|
|
+
|
|
|
+ return "confirm.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = true, validate = false)
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String createpage() {
|
|
|
+ // page navi
|
|
|
+ suggestElevateWordForm.initialize();
|
|
|
+ suggestElevateWordForm.crudMode = CommonConstants.CREATE_MODE;
|
|
|
+
|
|
|
+ return "edit.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = true, validate = false)
|
|
|
+ @Execute(validator = false, input = "error.jsp", urlPattern = "editpage/{crudMode}/{id}")
|
|
|
+ public String editpage() {
|
|
|
+ if (suggestElevateWordForm.crudMode != CommonConstants.EDIT_MODE) {
|
|
|
+ throw new ActionMessagesException("errors.crud_invalid_mode", new Object[] { CommonConstants.EDIT_MODE,
|
|
|
+ suggestElevateWordForm.crudMode });
|
|
|
+ }
|
|
|
+
|
|
|
+ loadSuggestElevateWord();
|
|
|
+
|
|
|
+ return "edit.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = true, validate = false)
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String editfromconfirm() {
|
|
|
+ suggestElevateWordForm.crudMode = CommonConstants.EDIT_MODE;
|
|
|
+
|
|
|
+ loadSuggestElevateWord();
|
|
|
+
|
|
|
+ return "edit.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = false, validate = true, keep = true)
|
|
|
+ @Execute(validator = true, input = "edit.jsp")
|
|
|
+ public String confirmfromcreate() {
|
|
|
+ return "confirm.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = false, validate = true, keep = true)
|
|
|
+ @Execute(validator = true, input = "edit.jsp")
|
|
|
+ public String confirmfromupdate() {
|
|
|
+ return "confirm.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = true, validate = false)
|
|
|
+ @Execute(validator = false, input = "error.jsp", urlPattern = "deletepage/{crudMode}/{id}")
|
|
|
+ public String deletepage() {
|
|
|
+ if (suggestElevateWordForm.crudMode != CommonConstants.DELETE_MODE) {
|
|
|
+ throw new ActionMessagesException("errors.crud_invalid_mode", new Object[] { CommonConstants.DELETE_MODE,
|
|
|
+ suggestElevateWordForm.crudMode });
|
|
|
+ }
|
|
|
+
|
|
|
+ loadSuggestElevateWord();
|
|
|
+
|
|
|
+ return "confirm.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ @Token(save = true, validate = false)
|
|
|
+ @Execute(validator = false, input = "error.jsp")
|
|
|
+ public String deletefromconfirm() {
|
|
|
+ suggestElevateWordForm.crudMode = CommonConstants.DELETE_MODE;
|
|
|
+
|
|
|
+ loadSuggestElevateWord();
|
|
|
+
|
|
|
+ return "confirm.jsp";
|
|
|
+ }
|
|
|
+
|
|
|
+ protected Map<String, String> createKeyMap() {
|
|
|
+ final Map<String, String> keys = new HashMap<String, String>();
|
|
|
+
|
|
|
+ keys.put("id", suggestElevateWordForm.id);
|
|
|
+
|
|
|
+ return keys;
|
|
|
+ }
|
|
|
+
|
|
|
public String getHelpLink() {
|
|
|
return systemHelper.getHelpLink("suggestElevateWord");
|
|
|
}
|
|
|
|
|
|
- @Override
|
|
|
protected void loadSuggestElevateWord() {
|
|
|
|
|
|
final SuggestElevateWord suggestElevateWord = suggestElevateWordService.getSuggestElevateWord(createKeyMap());
|
|
@@ -83,7 +259,6 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
FessBeans.copy(suggestElevateWord, suggestElevateWordForm).commonColumnDateConverter().excludes("searchParams", "mode").execute();
|
|
|
}
|
|
|
|
|
|
- @Override
|
|
|
protected SuggestElevateWord createSuggestElevateWord() {
|
|
|
SuggestElevateWord suggestElevateWord;
|
|
|
final String username = systemHelper.getUsername();
|
|
@@ -106,7 +281,6 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
return suggestElevateWord;
|
|
|
}
|
|
|
|
|
|
- @Override
|
|
|
@Token(save = false, validate = true)
|
|
|
@Execute(validator = true, input = "edit.jsp")
|
|
|
public String create() {
|
|
@@ -118,18 +292,17 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
|
|
|
return displayList(true);
|
|
|
} catch (final ActionMessagesException e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw e;
|
|
|
} catch (final CrudMessageException e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw new ActionMessagesException(e.getMessageId(), e.getArgs());
|
|
|
} catch (final Exception e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw new ActionMessagesException("errors.crud_failed_to_create_crud_table");
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- @Override
|
|
|
@Token(save = false, validate = true)
|
|
|
@Execute(validator = true, input = "edit.jsp")
|
|
|
public String update() {
|
|
@@ -141,18 +314,17 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
|
|
|
return displayList(true);
|
|
|
} catch (final ActionMessagesException e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw e;
|
|
|
} catch (final CrudMessageException e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw new ActionMessagesException(e.getMessageId(), e.getArgs());
|
|
|
} catch (final Exception e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw new ActionMessagesException("errors.crud_failed_to_update_crud_table");
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- @Override
|
|
|
@Execute(validator = false, input = "error.jsp")
|
|
|
public String delete() {
|
|
|
if (suggestElevateWordForm.crudMode != CommonConstants.DELETE_MODE) {
|
|
@@ -178,13 +350,13 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
|
|
|
return displayList(true);
|
|
|
} catch (final ActionMessagesException e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw e;
|
|
|
} catch (final CrudMessageException e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw new SSCActionMessagesException(e, e.getMessageId(), e.getArgs());
|
|
|
} catch (final Exception e) {
|
|
|
- log.error(e.getMessage(), e);
|
|
|
+ logger.error(e.getMessage(), e);
|
|
|
throw new SSCActionMessagesException(e, "errors.crud_failed_to_delete_crud_table");
|
|
|
}
|
|
|
}
|
|
@@ -208,7 +380,7 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
Constants.CSV_FILE_ENCODING_PROPERTY, Constants.UTF_8)))) {
|
|
|
suggestElevateWordService.exportCsv(writer);
|
|
|
} catch (final Exception e) {
|
|
|
- log.error("Failed to export data.", e);
|
|
|
+ logger.error("Failed to export data.", e);
|
|
|
throw new SSCActionMessagesException(e, "errors.failed_to_export_data");
|
|
|
}
|
|
|
return null;
|
|
@@ -239,9 +411,9 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
StreamUtil.drain(is, fos);
|
|
|
} catch (final Exception e) {
|
|
|
if (tempFile != null && !tempFile.delete()) {
|
|
|
- log.warn("Could not delete " + tempFile.getAbsolutePath());
|
|
|
+ logger.warn("Could not delete " + tempFile.getAbsolutePath());
|
|
|
}
|
|
|
- log.error("Failed to import data.", e);
|
|
|
+ logger.error("Failed to import data.", e);
|
|
|
throw new SSCActionMessagesException(e, "errors.failed_to_import_data");
|
|
|
} finally {
|
|
|
IOUtils.closeQuietly(is);
|
|
@@ -252,23 +424,22 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
try {
|
|
|
final String head = new String(b, Constants.UTF_8);
|
|
|
if (!(head.startsWith("\"SuggestWord\"") || head.startsWith("SuggestWord"))) {
|
|
|
- log.error("Unknown file: " + suggestElevateWordForm.suggestElevateWordFile);
|
|
|
+ logger.error("Unknown file: " + suggestElevateWordForm.suggestElevateWordFile);
|
|
|
throw new SSCActionMessagesException("errors.unknown_import_file");
|
|
|
}
|
|
|
final String enc = crawlerProperties.getProperty(Constants.CSV_FILE_ENCODING_PROPERTY, Constants.UTF_8);
|
|
|
new Thread(new Runnable() {
|
|
|
- @Override
|
|
|
public void run() {
|
|
|
Reader reader = null;
|
|
|
try {
|
|
|
reader = new BufferedReader(new InputStreamReader(new FileInputStream(oFile), enc));
|
|
|
suggestElevateWordService.importCsv(reader);
|
|
|
} catch (final Exception e) {
|
|
|
- log.error("Failed to import data.", e);
|
|
|
+ logger.error("Failed to import data.", e);
|
|
|
throw new FessSystemException("Failed to import data.", e);
|
|
|
} finally {
|
|
|
if (!oFile.delete()) {
|
|
|
- log.warn("Could not delete " + oFile.getAbsolutePath());
|
|
|
+ logger.warn("Could not delete " + oFile.getAbsolutePath());
|
|
|
}
|
|
|
IOUtils.closeQuietly(reader);
|
|
|
suggestHelper.storeAllElevateWords();
|
|
@@ -277,14 +448,14 @@ public class SuggestElevateWordAction extends BsSuggestElevateWordAction {
|
|
|
}).start();
|
|
|
} catch (final ActionMessagesException e) {
|
|
|
if (!oFile.delete()) {
|
|
|
- log.warn("Could not delete " + oFile.getAbsolutePath());
|
|
|
+ logger.warn("Could not delete " + oFile.getAbsolutePath());
|
|
|
}
|
|
|
throw e;
|
|
|
} catch (final Exception e) {
|
|
|
if (!oFile.delete()) {
|
|
|
- log.warn("Could not delete " + oFile.getAbsolutePath());
|
|
|
+ logger.warn("Could not delete " + oFile.getAbsolutePath());
|
|
|
}
|
|
|
- log.error("Failed to import data.", e);
|
|
|
+ logger.error("Failed to import data.", e);
|
|
|
throw new SSCActionMessagesException(e, "errors.failed_to_import_data");
|
|
|
}
|
|
|
SAStrutsUtil.addSessionMessage("success.upload_suggest_elevate_word");
|