com.openkm.servlet.admin.LanguageServlet.java Source code

Java tutorial

Introduction

Here is the source code for com.openkm.servlet.admin.LanguageServlet.java

Source

/**
 * 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;
    }
}