Java tutorial
/** * OpenKM, Open Document Management System (http://www.openkm.com) * Copyright (c) 2006-2017 Paco Avila & Josep Llort * <p> * No bytes were intentionally harmed during the development of this application. * <p> * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * <p> * 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 General Public License for more details. * <p> * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ package com.openkm.servlet.admin; import com.openkm.core.DatabaseException; import com.openkm.core.MimeTypeConfig; import com.openkm.dao.HibernateUtil; import com.openkm.dao.LanguageDAO; import com.openkm.dao.LegacyDAO; import com.openkm.dao.bean.Language; import com.openkm.dao.bean.Translation; import com.openkm.util.SecureStore; import com.openkm.util.UserActivity; import com.openkm.util.WarUtils; import com.openkm.util.WebUtils; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.FileItemFactory; import org.apache.commons.fileupload.FileUploadException; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; import org.apache.commons.io.IOUtils; import org.hibernate.Session; import org.hibernate.jdbc.Work; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import javax.servlet.ServletContext; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.*; import java.sql.Connection; import java.sql.SQLException; import java.sql.Statement; import java.util.*; /** * Language servlet */ public class LanguageServlet extends BaseServlet { private static final long serialVersionUID = 1L; private static Logger log = LoggerFactory.getLogger(LanguageServlet.class); @Override public void service(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { String method = request.getMethod(); if (checkMultipleInstancesAccess(request, response)) { if (method.equals(METHOD_GET)) { doGet(request, response); } else if (method.equals(METHOD_POST)) { doPost(request, response); } } } @Override public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { log.debug("doGet({}, {})", request, response); request.setCharacterEncoding("UTF-8"); String action = WebUtils.getString(request, "action"); String userId = request.getRemoteUser(); updateSessionManager(request); try { if (action.equals("edit")) { edit(userId, request, response); } else if (action.equals("delete")) { delete(userId, request, response); } else if (action.equals("create")) { create(userId, request, response); } else if (action.equals("translate")) { translate(userId, request, response); } else if (action.equals("flag")) { flag(userId, request, response); } else if (action.equals("export")) { export(userId, request, response); } else if (action.equals("addTranslation")) { addTranslation(userId, request, response); } else if (action.equals("normalize")) { normalize(request, response); } if (action.equals("") || WebUtils.getBoolean(request, "persist")) { list(userId, request, response); } } catch (DatabaseException e) { log.error(e.getMessage(), e); sendErrorRedirect(request, response, e); } } @Override @SuppressWarnings("unchecked") public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { log.debug("doPost({}, {})", request, response); request.setCharacterEncoding("UTF-8"); String action = WebUtils.getString(request, "action"); boolean persist = WebUtils.getBoolean(request, "persist"); String userId = request.getRemoteUser(); Session dbSession = null; updateSessionManager(request); try { if (ServletFileUpload.isMultipartContent(request)) { InputStream is = null; FileItemFactory factory = new DiskFileItemFactory(); ServletFileUpload upload = new ServletFileUpload(factory); List<FileItem> items = upload.parseRequest(request); Language lang = new Language(); byte data[] = null; for (Iterator<FileItem> it = items.iterator(); it.hasNext();) { FileItem item = it.next(); if (item.isFormField()) { if (item.getFieldName().equals("action")) { action = item.getString("UTF-8"); } else if (item.getFieldName().equals("lg_id")) { lang.setId(item.getString("UTF-8")); } else if (item.getFieldName().equals("lg_name")) { lang.setName(item.getString("UTF-8")); } else if (item.getFieldName().equals("persist")) { persist = true; } } else { is = item.getInputStream(); data = IOUtils.toByteArray(is); lang.setImageMime(MimeTypeConfig.mimeTypes.getContentType(item.getName())); is.close(); } } if (action.equals("create")) { lang.setImageContent(SecureStore.b64Encode(data)); LanguageDAO.create(lang); // Activity log UserActivity.log(request.getRemoteUser(), "ADMIN_LANGUAGE_CREATE", lang.getId(), null, lang.toString()); } else if (action.equals("edit")) { lang.setImageContent(SecureStore.b64Encode(data)); LanguageDAO.update(lang); // Activity log UserActivity.log(request.getRemoteUser(), "ADMIN_LANGUAGE_EDIT", lang.getId(), null, lang.toString()); } else if (action.equals("delete")) { LanguageDAO.delete(lang.getId()); // Activity log UserActivity.log(request.getRemoteUser(), "ADMIN_LANGUAGE_DELETE", lang.getId(), null, null); } else if (action.equals("import")) { dbSession = HibernateUtil.getSessionFactory().openSession(); importLanguage(userId, request, response, data, dbSession); // Activity log UserActivity.log(request.getRemoteUser(), "ADMIN_LANGUAGE_IMPORT", null, null, null); } } else if (action.equals("translate")) { translate(userId, request, response); } else if (action.equals("addTranslation")) { addTranslation(userId, request, response); } // Go to list response.sendRedirect(request.getContextPath() + request.getServletPath()); } catch (FileUploadException e) { log.error(e.getMessage(), e); sendErrorRedirect(request, response, e); } catch (DatabaseException e) { log.error(e.getMessage(), e); sendErrorRedirect(request, response, e); } catch (SQLException e) { log.error(e.getMessage(), e); sendErrorRedirect(request, response, e); } finally { HibernateUtil.close(dbSession); } } /** * List languages * * Translations reference is english */ private void list(String userId, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("list({}, {}, {})", new Object[] { userId, request, response }); ServletContext sc = getServletContext(); sc.setAttribute("langs", LanguageDAO.findAll()); sc.setAttribute("max", LanguageDAO.findByPk(Language.DEFAULT).getTranslations().size()); sc.getRequestDispatcher("/admin/language_list.jsp").forward(request, response); log.debug("list: void"); } /** * Delete language */ private void delete(String userId, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("delete({}, {}, {})", new Object[] { userId, request, response }); ServletContext sc = getServletContext(); String lgId = WebUtils.getString(request, "lg_id"); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("lg", LanguageDAO.findByPk(lgId)); sc.getRequestDispatcher("/admin/language_edit.jsp").forward(request, response); log.debug("delete: void"); } /** * Edit language */ private void edit(String userId, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("edit({}, {}, {})", new Object[] { userId, request, response }); ServletContext sc = getServletContext(); String lgId = WebUtils.getString(request, "lg_id"); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("lg", LanguageDAO.findByPk(lgId)); sc.getRequestDispatcher("/admin/language_edit.jsp").forward(request, response); log.debug("edit: void"); } /** * Create language */ private void create(String userId, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("edit({}, {}, {})", new Object[] { userId, request, response }); ServletContext sc = getServletContext(); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("lg", null); sc.getRequestDispatcher("/admin/language_edit.jsp").forward(request, response); log.debug("edit: void"); } /** * Create language */ private void addTranslation(String userId, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("addTranslation({}, {}, {})", new Object[] { userId, request, response }); if (WebUtils.getBoolean(request, "persist")) { Language lang = LanguageDAO.findByPk(Language.DEFAULT); Translation trans = new Translation(); trans.getTranslationId().setModule(WebUtils.getString(request, "tr_module")); trans.getTranslationId().setKey(WebUtils.getString(request, "tr_key")); trans.getTranslationId().setLanguage(lang.getId()); trans.setText(WebUtils.getString(request, "tr_text")); lang.getTranslations().add(trans); LanguageDAO.update(lang); } List<String> modules = new ArrayList<String>(); modules.add(Translation.MODULE_FRONTEND); modules.add(Translation.MODULE_EXTENSION); modules.add(Translation.MODULE_ADMINISTRATION); ServletContext sc = getServletContext(); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("tr_module", modules); sc.setAttribute("tr_key", ""); sc.setAttribute("tr_text", ""); sc.setAttribute("lang", LanguageDAO.findByPk(Language.DEFAULT)); sc.getRequestDispatcher("/admin/translation_add.jsp").forward(request, response); log.debug("addTranslation: void"); } /** * Translate language */ private void translate(String userId, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("translate({}, {}, {})", new Object[] { userId, request, response }); Language langBase = LanguageDAO.findByPk(Language.DEFAULT); // English always it'll be used as a translations base Set<Translation> translationsBase = langBase.getTranslations(); List<String> modules = new ArrayList<>(); modules.add(""); modules.add(Translation.MODULE_FRONTEND); modules.add(Translation.MODULE_EXTENSION); modules.add(Translation.MODULE_MOBILE); if (WebUtils.getBoolean(request, "persist")) { Set<Translation> newTranslations = new HashSet<Translation>(); String lgId = WebUtils.getString(request, "lg_id"); Language lang = LanguageDAO.findByPk(lgId); for (Translation translation : translationsBase) { String text = request.getParameter( translation.getTranslationId().getModule() + "-" + translation.getTranslationId().getKey()); if (text != null && !text.equals("")) { Translation newTranslation = new Translation(); newTranslation.getTranslationId().setModule(translation.getTranslationId().getModule()); newTranslation.getTranslationId().setKey(translation.getTranslationId().getKey()); newTranslation.getTranslationId().setLanguage(lang.getId()); newTranslation.setText(text); newTranslations.add(newTranslation); } } lang.setTranslations(newTranslations); LanguageDAO.update(lang); } else { ServletContext sc = getServletContext(); String lgId = WebUtils.getString(request, "lg_id"); String filter = WebUtils.getString(request, "filter"); String module = WebUtils.getString(request, "module"); Language langToTranslate = LanguageDAO.findByPk(lgId); Map<String, String> translations = new HashMap<String, String>(); if (filter.isEmpty() && module.isEmpty()) { for (Translation translation : langToTranslate.getTranslations()) { translations.put(translation.getTranslationId().getModule() + "-" + translation.getTranslationId().getKey(), translation.getText()); } } else { // Filter translationsBase Set<Translation> translationsToRemove = new HashSet<>(); for (Translation translation : translationsBase) { if (module.isEmpty() && !translation.getTranslationId().getKey().contains(filter) || filter.isEmpty() && !translation.getTranslationId().getModule().contains(module) || (!translation.getTranslationId().getKey().contains(filter) || !translation.getTranslationId().getModule().contains(module))) { translationsToRemove.add(translation); } } translationsBase.removeAll(translationsToRemove); // Filter others translations for (Translation translation : langToTranslate.getTranslations()) { if (module.isEmpty() && translation.getTranslationId().getKey().contains(filter) || filter.isEmpty() && translation.getTranslationId().getModule().contains(module) || (translation.getTranslationId().getKey().contains(filter) && translation.getTranslationId().getModule().contains(module))) { translations.put(translation.getTranslationId().getModule() + "-" + translation.getTranslationId().getKey(), translation.getText()); } } } sc.setAttribute("module", module); sc.setAttribute("tr_modules", modules); sc.setAttribute("filter", filter); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("lg_id", lgId); sc.setAttribute("langToTranslateName", langToTranslate.getName()); sc.setAttribute("langBaseName", langBase.getName()); sc.setAttribute("translations", translations); sc.setAttribute("translationsBase", asSortedList(translationsBase)); sc.getRequestDispatcher("/admin/translation_edit.jsp").forward(request, response); } log.debug("translate: void"); } /** * Show language flag icon */ private void flag(String userId, HttpServletRequest request, HttpServletResponse response) throws DatabaseException, IOException { log.debug("flag({}, {}, {})", new Object[] { userId, request, response }); String lgId = WebUtils.getString(request, "lg_id"); ServletOutputStream out = response.getOutputStream(); Language language = LanguageDAO.findByPk(lgId); byte[] img = SecureStore.b64Decode(new String(language.getImageContent())); response.setContentType(language.getImageMime()); response.setContentLength(img.length); out.write(img); out.flush(); log.debug("flag: void"); } private void export(String userId, HttpServletRequest request, HttpServletResponse response) throws DatabaseException, IOException { log.debug("export({}, {}, {})", new Object[] { userId, request, response }); String lgId = WebUtils.getString(request, "lg_id"); Language language = LanguageDAO.findByPk(lgId); // Disable browser cache response.setHeader("Expires", "Sat, 6 May 1971 12:00:00 GMT"); response.setHeader("Cache-Control", "max-age=0, must-revalidate"); response.addHeader("Cache-Control", "post-check=0, pre-check=0"); String fileName = "OpenKM_" + WarUtils.getAppVersion().getVersion() + "_" + language.getId() + ".sql"; response.setHeader("Content-disposition", "inline; filename=\"" + fileName + "\""); response.setContentType("text/x-sql; charset=UTF-8"); PrintWriter out = new PrintWriter(new OutputStreamWriter(response.getOutputStream(), "UTF8"), true); out.println("DELETE FROM OKM_TRANSLATION WHERE TR_LANGUAGE='" + language.getId() + "';"); out.println("DELETE FROM OKM_LANGUAGE WHERE LG_ID='" + language.getId() + "';"); StringBuffer insertLang = new StringBuffer( "INSERT INTO OKM_LANGUAGE (LG_ID, LG_NAME, LG_IMAGE_CONTENT, LG_IMAGE_MIME) VALUES ('"); insertLang.append(language.getId()).append("', '"); insertLang.append(language.getName()).append("', '"); insertLang.append(language.getImageContent()).append("', '"); insertLang.append(language.getImageMime()).append("');"); out.println(insertLang); for (Translation translation : language.getTranslations()) { StringBuffer insertTranslation = new StringBuffer( "INSERT INTO OKM_TRANSLATION (TR_MODULE, TR_KEY, TR_TEXT, TR_LANGUAGE) VALUES ("); insertTranslation.append("'"); insertTranslation.append(translation.getTranslationId().getModule()).append("', '"); insertTranslation.append(translation.getTranslationId().getKey()).append("', '"); insertTranslation.append(translation.getText().replaceAll("'", "''")).append("', '"); // replace ' to '' in translation text insertTranslation.append(language.getId()).append("');"); out.println(insertTranslation); } out.flush(); log.debug("export: void"); } /** * Import a new language into database */ private void importLanguage(String userId, HttpServletRequest request, HttpServletResponse response, final byte[] data, Session dbSession) throws DatabaseException, IOException, SQLException { log.debug("importLanguage({}, {}, {}, {}, {})", new Object[] { userId, request, response, data, dbSession }); // Because need to be final and an array can be modified being final final String[] insertLanguage = new String[1]; dbSession.doWork(new Work() { @Override public void execute(Connection con) throws SQLException { Statement stmt = con.createStatement(); InputStreamReader is = new InputStreamReader(new ByteArrayInputStream(data)); BufferedReader br = new BufferedReader(is); String query; try { while ((query = br.readLine()) != null) { // Used to get the inserted language id if (query.indexOf("INSERT INTO OKM_LANGUAGE") >= 0) { insertLanguage[0] = query; } stmt.executeUpdate(query); } } catch (IOException e) { throw new SQLException(e.getMessage(), e); } LegacyDAO.close(stmt); } }); // Normalize imported language LanguageDAO.refresh(); for (Language language : LanguageDAO.findAll()) { // Check for inserted language id if (insertLanguage[0].indexOf(language.getId()) > 0) { LanguageDAO.normalizeTranslation(language); break; } } // Clean language cache again LanguageDAO.refresh(); log.debug("importLanguage: void"); } /** * Normalize languages */ private void normalize(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("normalize({}, {})", new Object[] { request, response }); for (Language language : LanguageDAO.findAll()) { if (!Language.DEFAULT.equalsIgnoreCase(language.getId())) { LanguageDAO.normalizeTranslation(language); } } // Go to list response.sendRedirect(request.getContextPath() + request.getServletPath()); log.debug("normalize: void"); } /** * Sort set */ private List<Translation> asSortedList(Set<Translation> c) { List<Translation> list = new ArrayList<>(c); java.util.Collections.sort(list, new Comparator<Translation>() { @Override public int compare(Translation o1, Translation o2) { return o1.getTranslationId().getKey().compareTo(o2.getTranslationId().getKey()); } }); return list; } }