/** * OpenKM, Open Document Management System (http://www.openkm.com) * Copyright (c) 2006-2011 Paco Avila & Josep Llort * * No bytes were intentionally harmed during the development of this application. * * 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. * * 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. * * 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 java.io.IOException; import java.security.NoSuchAlgorithmException; import java.util.HashSet; import javax.jcr.Session; import javax.servlet.ServletContext; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.openkm.api.OKMPropertyGroup; import com.openkm.api.OKMWorkflow; import com.openkm.core.DatabaseException; import com.openkm.core.ParseException; import com.openkm.core.RepositoryException; import com.openkm.core.WorkflowException; import com.openkm.dao.ProfileDAO; import com.openkm.dao.ReportDAO; import com.openkm.dao.bean.Profile; import com.openkm.extension.dao.ExtensionDAO; import com.openkm.jcr.JCRUtils; import com.openkm.util.UserActivity; import com.openkm.util.WebUtils; /** * User profiles servlet */ public class ProfileServlet extends BaseServlet { private static final long serialVersionUID = 1L; private static Logger log = LoggerFactory.getLogger(ProfileServlet.class); 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"); Session session = null; updateSessionManager(request); try { session = JCRUtils.getSession(); if (action.equals("create")) { create(session, request, response); } else if (action.equals("edit")) { edit(session, request, response); } else if (action.equals("delete")) { delete(session, request, response); } if (action.equals("") || WebUtils.getBoolean(request, "persist")) { list(session, request, response); } } catch (javax.jcr.LoginException e) { log.error(e.getMessage(), e); sendErrorRedirect(request,response, e); } catch (javax.jcr.RepositoryException e) { log.error(e.getMessage(), e); sendErrorRedirect(request,response, e); } catch (DatabaseException e) { log.error(e.getMessage(), e); sendErrorRedirect(request,response, e); } catch (NoSuchAlgorithmException e) { log.error(e.getMessage(), e); sendErrorRedirect(request,response, e); } catch (RepositoryException e) { log.error(e.getMessage(), e); sendErrorRedirect(request,response, e); } catch (ParseException e) { log.error(e.getMessage(), e); sendErrorRedirect(request,response, e); } catch (WorkflowException e) { log.error(e.getMessage(), e); sendErrorRedirect(request,response, e); } finally { JCRUtils.logout(session); } } /** * New user */ private void create(Session session, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException, RepositoryException, ParseException, WorkflowException { log.debug("create({}, {}, {})", new Object[] { session, request, response }); if (WebUtils.getBoolean(request, "persist")) { Profile prf = getUserProfile(request); int id = ProfileDAO.create(prf); // Activity log UserActivity.log(session.getUserID(), "ADMIN_USER_PROFILE_CREATE", Integer.toString(id), prf.toString()); } else { ServletContext sc = getServletContext(); Profile prf = new Profile(); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("exts", ExtensionDAO.findAll()); sc.setAttribute("reps", ReportDAO.findAll()); sc.setAttribute("pgroups", OKMPropertyGroup.getInstance().getAllGroups(null)); sc.setAttribute("wflows", OKMWorkflow.getInstance().findAllProcessDefinitions(null)); sc.setAttribute("prf", prf); sc.getRequestDispatcher("/admin/profile_edit.jsp").forward(request, response); } log.debug("create: void"); } /** * Edit user */ private void edit(Session session, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException, NoSuchAlgorithmException, RepositoryException, ParseException, WorkflowException { log.debug("edit({}, {}, {})", new Object[] { session, request, response }); if (WebUtils.getBoolean(request, "persist")) { Profile prf = getUserProfile(request); ProfileDAO.update(prf); // Activity log UserActivity.log(session.getUserID(), "ADMIN_USER_PROFILE_EDIT", Integer.toString(prf.getId()), prf.toString()); } else { ServletContext sc = getServletContext(); int prfId = WebUtils.getInt(request, "prf_id"); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("exts", ExtensionDAO.findAll()); sc.setAttribute("reps", ReportDAO.findAll()); sc.setAttribute("pgroups", OKMPropertyGroup.getInstance().getAllGroups(null)); sc.setAttribute("wflows", OKMWorkflow.getInstance().findAllProcessDefinitions(null)); sc.setAttribute("prf", ProfileDAO.findByPk(prfId)); sc.getRequestDispatcher("/admin/profile_edit.jsp").forward(request, response); } log.debug("edit: void"); } /** * Update user */ private void delete(Session session, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException, NoSuchAlgorithmException, RepositoryException, ParseException, WorkflowException { log.debug("delete({}, {}, {})", new Object[] { session, request, response }); if (WebUtils.getBoolean(request, "persist")) { int prfId = WebUtils.getInt(request, "prf_id"); ProfileDAO.delete(prfId); // Activity log UserActivity.log(session.getUserID(), "ADMIN_USER_PROFILE_DELETE", Integer.toString(prfId), null); } else { ServletContext sc = getServletContext(); int prfId = WebUtils.getInt(request, "prf_id"); sc.setAttribute("action", WebUtils.getString(request, "action")); sc.setAttribute("persist", true); sc.setAttribute("exts", ExtensionDAO.findAll()); sc.setAttribute("reps", ReportDAO.findAll()); sc.setAttribute("pgroups", OKMPropertyGroup.getInstance().getAllGroups(null)); sc.setAttribute("wflows", OKMWorkflow.getInstance().findAllProcessDefinitions(null)); sc.setAttribute("prf", ProfileDAO.findByPk(prfId)); sc.getRequestDispatcher("/admin/profile_edit.jsp").forward(request, response); } log.debug("delete: void"); } /** * List user profiles */ private void list(Session session, HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException, DatabaseException { log.debug("list({}, {}, {})", new Object[] { session, request, response }); ServletContext sc = getServletContext(); sc.setAttribute("userProfiles", ProfileDAO.findAll(false)); sc.getRequestDispatcher("/admin/profile_list.jsp").forward(request, response); log.debug("list: void"); } /** * Fille user profile object */ private Profile getUserProfile(HttpServletRequest request) { Profile prf = new Profile(); prf.setId(WebUtils.getInt(request, "prf_id")); prf.setName(WebUtils.getString(request, "prf_name")); prf.setActive(WebUtils.getBoolean(request, "prf_active")); // Misc prf.getMisc().setUserQuota(WebUtils.getLong(request, "prf_misc_user_quota")); prf.getMisc().setAdvancedFilters(WebUtils.getBoolean(request, "prf_misc_advanced_filter")); prf.getMisc().setWebSkin(WebUtils.getString(request, "prf_misc_web_skin")); prf.getMisc().setPrintPreview(WebUtils.getBoolean(request, "prf_misc_print_preview")); prf.getMisc().setKeywordsEnabled(WebUtils.getBoolean(request, "prf_misc_keywords_enabled")); prf.getMisc().setExtensions(new HashSet<String>(WebUtils.getStringList(request, "prf_misc_extensions"))); prf.getMisc().setReports(new HashSet<Integer>(WebUtils.getIntList(request, "prf_misc_reports"))); // Wizard prf.getWizard().setKeywordsEnabled(WebUtils.getBoolean(request, "prf_wizard_keywords")); prf.getWizard().setCategoriesEnabled(WebUtils.getBoolean(request, "prf_wizard_categories")); prf.getWizard().setPropertyGroups(new HashSet<String>(WebUtils.getStringList(request, "prf_wizard_property_groups"))); prf.getWizard().setWorkflows(new HashSet<String>(WebUtils.getStringList(request, "prf_wizard_workflows"))); // Chat prf.getChat().setChatEnabled(WebUtils.getBoolean(request, "prf_chat_enabled")); prf.getChat().setAutoLoginEnabled(WebUtils.getBoolean(request, "prf_chat_auto_login")); // Stack prf.getStack().setTaxonomyVisible(WebUtils.getBoolean(request, "prf_stack_taxonomy_visible")); prf.getStack().setCategoriesVisible(WebUtils.getBoolean(request, "prf_stack_categories_visible")); prf.getStack().setThesaurusVisible(WebUtils.getBoolean(request, "prf_stack_thesaurus_visible")); prf.getStack().setTemplatesVisible(WebUtils.getBoolean(request, "prf_stack_templates_visible")); prf.getStack().setPersonalVisible(WebUtils.getBoolean(request, "prf_stack_personal_visible")); prf.getStack().setMailVisible(WebUtils.getBoolean(request, "prf_stack_mail_visible")); prf.getStack().setTrashVisible(WebUtils.getBoolean(request, "prf_stack_trash_visible")); // Menu prf.getMenu().setFileVisible(WebUtils.getBoolean(request, "prf_menu_file_visible")); prf.getMenu().setEditVisible(WebUtils.getBoolean(request, "prf_menu_edit_visible")); prf.getMenu().setToolsVisible(WebUtils.getBoolean(request, "prf_menu_tools_visible")); prf.getMenu().setBookmarksVisible(WebUtils.getBoolean(request, "prf_menu_bookmarks_visible")); prf.getMenu().setHelpVisible(WebUtils.getBoolean(request, "prf_menu_help_visible")); // Menu File prf.getMenu().getFile().setCreateFolderVisible(WebUtils.getBoolean(request, "prf_menu_file_create_folder_visible")); prf.getMenu().getFile().setFindFolderVisible(WebUtils.getBoolean(request, "prf_menu_file_find_folder_visible")); prf.getMenu().getFile().setGoFolderVisible(WebUtils.getBoolean(request, "prf_menu_file_go_folder_visible")); prf.getMenu().getFile().setDownloadVisible(WebUtils.getBoolean(request, "prf_menu_file_download_visible")); prf.getMenu().getFile().setDownloadPdfVisible(WebUtils.getBoolean(request, "prf_menu_file_download_pdf_visible")); prf.getMenu().getFile().setAddDocumentVisible(WebUtils.getBoolean(request, "prf_menu_file_add_document_visible")); prf.getMenu().getFile().setStartWorkflowVisible(WebUtils.getBoolean(request, "prf_menu_file_start_workflow_visible")); prf.getMenu().getFile().setRefreshVisible(WebUtils.getBoolean(request, "prf_menu_file_refresh_visible")); prf.getMenu().getFile().setScannerVisible(WebUtils.getBoolean(request, "prf_menu_file_scanner_visible")); prf.getMenu().getFile().setUploaderVisible(WebUtils.getBoolean(request, "prf_menu_file_uploader_visible")); prf.getMenu().getFile().setExportVisible(WebUtils.getBoolean(request, "prf_menu_file_export_visible")); prf.getMenu().getFile().setCreateFromTemplateVisible(WebUtils.getBoolean(request, "prf_menu_file_create_from_template_visible")); prf.getMenu().getFile().setPurgeVisible(WebUtils.getBoolean(request, "prf_menu_file_purge_visible")); prf.getMenu().getFile().setPurgeTrashVisible(WebUtils.getBoolean(request, "prf_menu_file_purge_trash_visible")); prf.getMenu().getFile().setRestoreVisible(WebUtils.getBoolean(request, "prf_menu_file_restore_visible")); prf.getMenu().getFile().setSendDocumentLinkVisible(WebUtils.getBoolean(request, "prf_menu_file_send_document_link_visible")); prf.getMenu().getFile().setSendDocumentAttachmentVisible(WebUtils.getBoolean(request, "prf_menu_file_send_document_attachment_visible")); // Menu Bookmarks prf.getMenu().getBookmark().setManageBookmarksVisible(WebUtils.getBoolean(request, "prf_menu_bookmark_manage_bookmarks_visible")); prf.getMenu().getBookmark().setAddBookmarkVisible(WebUtils.getBoolean(request, "prf_menu_bookmark_add_bookmark_visible")); prf.getMenu().getBookmark().setSetHomeVisible(WebUtils.getBoolean(request, "prf_menu_bookmark_set_home_visible")); prf.getMenu().getBookmark().setGoHomeVisible(WebUtils.getBoolean(request, "prf_menu_bookmark_go_home_visible")); // Menu Tools prf.getMenu().getTool().setLanguagesVisible(WebUtils.getBoolean(request, "prf_menu_tool_languages_visible")); prf.getMenu().getTool().setSkinVisible(WebUtils.getBoolean(request, "prf_menu_tool_skin_visible")); prf.getMenu().getTool().setDebugVisible(WebUtils.getBoolean(request, "prf_menu_tool_debug_visible")); prf.getMenu().getTool().setAdministrationVisible(WebUtils.getBoolean(request, "prf_menu_tool_administration_visible")); prf.getMenu().getTool().setPreferencesVisible(WebUtils.getBoolean(request, "prf_menu_tool_preferences_visible")); // Menu Edit prf.getMenu().getEdit().setRenameVisible(WebUtils.getBoolean(request, "prf_menu_edit_rename_visible")); prf.getMenu().getEdit().setCopyVisible(WebUtils.getBoolean(request, "prf_menu_edit_copy_visible")); prf.getMenu().getEdit().setMoveVisible(WebUtils.getBoolean(request, "prf_menu_edit_move_visible")); prf.getMenu().getEdit().setLockVisible(WebUtils.getBoolean(request, "prf_menu_edit_lock_visible")); prf.getMenu().getEdit().setUnlockVisible(WebUtils.getBoolean(request, "prf_menu_edit_unlock_visible")); prf.getMenu().getEdit().setCheckInVisible(WebUtils.getBoolean(request, "prf_menu_edit_check_in_visible")); prf.getMenu().getEdit().setCheckOutVisible(WebUtils.getBoolean(request, "prf_menu_edit_check_out_visible")); //added by vissu on feb19 for zohoapi prf.getMenu().getEdit().setZohoVisible(WebUtils.getBoolean(request, "prf_menu_edit_zoho_visible")); prf.getMenu().getEdit().setCancelCheckOutVisible(WebUtils.getBoolean(request, "prf_menu_edit_cancel_check_out_visible")); prf.getMenu().getEdit().setDeleteVisible(WebUtils.getBoolean(request, "prf_menu_edit_delete_visible")); prf.getMenu().getEdit().setAddPropertyGroupVisible(WebUtils.getBoolean(request, "prf_menu_edit_add_property_group_visible")); prf.getMenu().getEdit().setRemovePropertyGroupVisible(WebUtils.getBoolean(request, "prf_menu_edit_remove_property_group_visible")); prf.getMenu().getEdit().setAddSubscriptionVisible(WebUtils.getBoolean(request, "prf_menu_edit_add_subscription_visible")); prf.getMenu().getEdit().setRemoveSubscriptionVisible(WebUtils.getBoolean(request, "prf_menu_edit_remove_subscription_visible")); // Menu Help prf.getMenu().getHelp().setHelpVisible(WebUtils.getBoolean(request, "prf_menu_help_help_visible")); prf.getMenu().getHelp().setDocumentationVisible(WebUtils.getBoolean(request, "prf_menu_help_documentation_visible")); prf.getMenu().getHelp().setBugTrackingVisible(WebUtils.getBoolean(request, "prf_menu_help_bug_tracking_visible")); prf.getMenu().getHelp().setSupportVisible(WebUtils.getBoolean(request, "prf_menu_help_support_visible")); prf.getMenu().getHelp().setForumVisible(WebUtils.getBoolean(request, "prf_menu_help_forum_visible")); prf.getMenu().getHelp().setChangelogVisible(WebUtils.getBoolean(request, "prf_menu_help_changelog_visible")); prf.getMenu().getHelp().setWebSiteVisible(WebUtils.getBoolean(request, "prf_menu_help_web_site_visible")); prf.getMenu().getHelp().setAboutVisible(WebUtils.getBoolean(request, "prf_menu_help_about_visible")); // Tab prf.getTab().setDesktopVisible(WebUtils.getBoolean(request, "prf_tab_desktop_visible")); prf.getTab().setSearchVisible(WebUtils.getBoolean(request, "prf_tab_search_visible")); prf.getTab().setDashboardVisible(WebUtils.getBoolean(request, "prf_tab_dashboard_visible")); prf.getTab().setAdministrationVisible(WebUtils.getBoolean(request, "prf_tab_administration_visible")); // Tab Document prf.getTab().getDocument().setPropertiesVisible(WebUtils.getBoolean(request, "prf_tab_document_properties_visible")); prf.getTab().getDocument().setSecurityVisible(WebUtils.getBoolean(request, "prf_tab_document_security_visible")); prf.getTab().getDocument().setNotesVisible(WebUtils.getBoolean(request, "prf_tab_document_notes_visible")); prf.getTab().getDocument().setVersionsVisible(WebUtils.getBoolean(request, "prf_tab_document_versions_visible")); prf.getTab().getDocument().setPreviewVisible(WebUtils.getBoolean(request, "prf_tab_document_preview_visible")); prf.getTab().getDocument().setPropertyGroupsVisible(WebUtils.getBoolean(request, "prf_tab_document_property_groups_visible")); // Tab Folder prf.getTab().getFolder().setPropertiesVisible(WebUtils.getBoolean(request, "prf_tab_folder_properties_visible")); prf.getTab().getFolder().setSecurityVisible(WebUtils.getBoolean(request, "prf_tab_folder_security_visible")); prf.getTab().getFolder().setNotesVisible(WebUtils.getBoolean(request, "prf_tab_folder_notes_visible")); // Tab Mail prf.getTab().getMail().setPropertiesVisible(WebUtils.getBoolean(request, "prf_tab_mail_properties_visible")); prf.getTab().getMail().setSecurityVisible(WebUtils.getBoolean(request, "prf_tab_mail_security_visible")); // Dashboard prf.getDashboard().setUserVisible(WebUtils.getBoolean(request, "prf_dashboard_user_visible")); prf.getDashboard().setMailVisible(WebUtils.getBoolean(request, "prf_dashboard_mail_visible")); prf.getDashboard().setNewsVisible(WebUtils.getBoolean(request, "prf_dashboard_news_visible")); prf.getDashboard().setGeneralVisible(WebUtils.getBoolean(request, "prf_dashboard_general_visible")); prf.getDashboard().setWorkflowVisible(WebUtils.getBoolean(request, "prf_dashboard_workflow_visible")); prf.getDashboard().setKeywordsVisible(WebUtils.getBoolean(request, "prf_dashboard_keywords_visible")); return prf; } }