/* * #%L * Alfresco Records Management Module * %% * Copyright (C) 2005 - 2016 Alfresco Software Limited * %% * This file is part of the Alfresco software. * - * If the software was purchased under a paid Alfresco license, the terms of * the paid license agreement will prevail. Otherwise, the software is * provided under the following open source license terms: * - * Alfresco 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 3 of the License, or * (at your option) any later version. * - * Alfresco 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. * - * You should have received a copy of the GNU Lesser General Public License * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. * #L% */ package org.alfresco.module.org_alfresco_module_rm.script; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import org.alfresco.module.org_alfresco_module_rm.dataset.DataSet; import org.alfresco.module.org_alfresco_module_rm.dataset.DataSetService; import org.alfresco.module.org_alfresco_module_rm.model.rma.type.RmSiteType; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.cmr.site.SiteService; import org.apache.commons.lang.StringUtils; import org.springframework.extensions.webscripts.Cache; import org.springframework.extensions.webscripts.DeclarativeWebScript; import org.springframework.extensions.webscripts.Status; import org.springframework.extensions.webscripts.WebScriptRequest; public class DataSetsGet extends DeclarativeWebScript { /** Constant for the site name parameter */ private static final String ARG_SITE_NAME = "site"; /** Constant for the unloadedonly parameter */ private static final String ARG_UNLOADED_ONLY = "unloadedonly"; /** Data set service */ private DataSetService dataSetService; /** Site service */ private SiteService siteService; /** * Set data set service * * @param dataSetService the data set service */ public void setDataSetService(DataSetService dataSetService) { this.dataSetService = dataSetService; } /** * Set site service * * @param siteService the site service */ public void setSiteService(SiteService siteService) { this.siteService = siteService; } /** * @see org.springframework.extensions.webscripts.DeclarativeWebScript#executeImpl(org.springframework.extensions.webscripts.WebScriptRequest, * org.springframework.extensions.webscripts.Status, * org.springframework.extensions.webscripts.Cache) */ @Override protected Map<String, Object> executeImpl(WebScriptRequest req, Status status, Cache cache) { // Get the site name from the URL and find out the file plan String siteName = req.getParameter(ARG_SITE_NAME); if (StringUtils.isBlank(siteName)) { siteName = RmSiteType.DEFAULT_SITE_NAME; } NodeRef filePlan = siteService.getContainer(siteName, RmSiteType.COMPONENT_DOCUMENT_LIBRARY); // Check if only unloaded data sets should be returned - default value is false String unloadedOnlyParam = req.getParameter(ARG_UNLOADED_ONLY); boolean unloadedOnly = false; if (StringUtils.isNotBlank(unloadedOnlyParam)) { unloadedOnly = Boolean.valueOf(unloadedOnlyParam).booleanValue(); } // Get the loaded/unloaded data sets depending on the "unloadedOnly" parameter Map<String, DataSet> dataSets = dataSetService.getDataSets(filePlan, unloadedOnly); List<Map<String, String>> dataSetList = new ArrayList<Map<String, String>>(dataSets.size()); for (Map.Entry<String, DataSet> entry : dataSets.entrySet()) { Map<String, String> dataSet = new HashMap<String, String>(3); DataSet value = entry.getValue(); // Data set details String dataSetId = value.getId(); String isLoaded = String.valueOf(dataSetService.isLoadedDataSet(filePlan, dataSetId)); dataSet.put("label", value.getLabel()); dataSet.put("id", dataSetId); dataSet.put("isLoaded", isLoaded); // Add data set to the list dataSetList.add(dataSet); } Map<String, Object> model = new HashMap<String, Object>(1); model.put("datasets", dataSetList); return model; } }