⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 transfer.java

📁 联合国农粮署牵头开发的geonetwork源代码最新版
💻 JAVA
字号:
//=============================================================================//===	Copyright (C) 2001-2007 Food and Agriculture Organization of the//===	United Nations (FAO-UN), United Nations World Food Programme (WFP)//===	and United Nations Environment Programme (UNEP)//===//===	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 St, Fifth Floor, Boston, MA 02110-1301, USA//===//===	Contact: Jeroen Ticheler - FAO - Viale delle Terme di Caracalla 2,//===	Rome - Italy. email: geonetwork@osgeo.org//==============================================================================package org.fao.geonet.services.ownership;import java.sql.SQLException;import java.util.HashSet;import java.util.List;import java.util.Set;import java.util.StringTokenizer;import jeeves.interfaces.Service;import jeeves.resources.dbms.Dbms;import jeeves.server.ServiceConfig;import jeeves.server.context.ServiceContext;import jeeves.utils.Util;import org.fao.geonet.GeonetContext;import org.fao.geonet.constants.Geonet;import org.fao.geonet.kernel.DataManager;import org.jdom.Element;//=============================================================================public class Transfer implements Service{	public void init(String appPath, ServiceConfig params) throws Exception {}	//--------------------------------------------------------------------------	//---	//--- Service	//---	//--------------------------------------------------------------------------	public Element exec(Element params, ServiceContext context) throws Exception	{		int sourceUsr = Util.getParamAsInt(params, "sourceUser");		int sourceGrp = Util.getParamAsInt(params, "sourceGroup");		int targetUsr = Util.getParamAsInt(params, "targetUser");		int targetGrp = Util.getParamAsInt(params, "targetGroup");		GeonetContext gc = (GeonetContext) context.getHandlerContext(Geonet.CONTEXT_NAME);		DataManager   dm = gc.getDataManager();		Dbms dbms = (Dbms) context.getResourceManager().open(Geonet.Res.MAIN_DB);		//--- transfer privileges (if case)		Set<String> sourcePriv = retrievePrivileges(dbms, sourceUsr, sourceGrp);		Set<String> targetPriv = retrievePrivileges(dbms, targetUsr, targetGrp);		//--- a commit just to release some resources		dbms.commit();		int privCount = 0;		Set<Integer> metadata = new HashSet<Integer>();		for (String priv : sourcePriv)		{			StringTokenizer st = new StringTokenizer(priv, "|");			int opId = Integer.parseInt(st.nextToken());			int mdId = Integer.parseInt(st.nextToken());			dm.unsetOperation(dbms, mdId, sourceGrp, opId);			if (!targetPriv.contains(priv))				dbms.execute("INSERT INTO OperationAllowed(metadataId, groupId, operationId) " +								 "VALUES(?,?,?)", mdId, targetGrp, opId);			dbms.execute("UPDATE Metadata SET owner=? WHERE id=?", targetUsr, mdId);			metadata.add(mdId);			privCount++;		}		dbms.commit();		//--- reindex metadata		for (int mdId : metadata)			dm.indexMetadata(dbms, Integer.toString(mdId));		//--- return summary		return new Element("response")			.addContent(new Element("privileges").setText(privCount      +""))			.addContent(new Element("metadata")  .setText(metadata.size()+""));	}	//--------------------------------------------------------------------------	private Set<String> retrievePrivileges(Dbms dbms, int userId, int groupId) throws SQLException	{		String query = "SELECT * "+							"FROM OperationAllowed, Metadata "+							"WHERE metadataId=id AND owner=? AND groupId=?";		List list = dbms.select(query, userId, groupId).getChildren();		Set<String> result = new HashSet<String>();		for (Object o : list)		{			Element elem = (Element) o;			String  opId = elem.getChildText("operationid");			String  mdId = elem.getChildText("metadataid");			result.add(opId +"|"+ mdId);		}		return result;	}}//=============================================================================

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -