Windchill 11 之設置修改者

修改對象的修改者要看業務場景:
1、如果只是修改這個對象的修改者屬性,可用下面setModifier方法

/**
     * 設置對象的修改者
     * @param obj  Persistence對象
     * @param uref WTPrincipalReference對象
     * @throws Exception
     */
    public static void setModifier(Iterated obj, WTPrincipalReference uref) throws Exception {
		try {
			obj.getCreator();
			Class[] pp = new Class[] { WTPrincipalReference.class };
			Method setCreator = _IterationInfo.class.getDeclaredMethod("setModifier", pp);
			setCreator.setAccessible(true);
			setCreator.invoke(obj.getIterationInfo(), new Object[] { uref });
		} catch (Exception e) {
			// System.out.println(">>>Error:" + e.toString());
			e.printStackTrace();
			throw e;
		}

	}

例子:


/*
*1)先根據用戶名獲取到用戶
*2)根據WTUser對象New一個WTPrincipalReference  
*3)調用setModifier()方法更新對象的修改者,**記得在設置對象修改者前刷新下對象拿到最新版本**
*4)因爲修改者只是對象的一個屬性,設置成功後需要自己調用方法持久化對象
*5)**兩種持久化方法**:
	A:PersistenceServerHelper.manager.*;----PersistenceServerHelper相對簡單粗暴,單純執行
	    PersistenceServerHelper.manager.insert(partAfter);
	    PersistenceServerHelper.manager.update(partAfter);
	    PersistenceServerHelper.manager.remove(partAfter);
	    PersistenceServerHelper.manager.restore(partAfter);
	    PersistenceServerHelper.manager.store(Persistable arg0, Timestamp arg1, Timestamp arg2);
	    
	B:PersistenceHelper.manager.*;--PersistenceHelper執行時,考慮全面,如權限,關聯對象,標準用法
	PersistenceHelper.manager.save(Persistable)
	PersistenceHelper.manager.delete(Persistable)
	PersistenceHelper.manager.store(Persistable)
	PersistenceHelper.manager.refresh(Persistable);
*/
	WTUser user = getUserByName(“Wonly.Wu”);
	WTPrincipalReference  uref =WTPrincipalReference.newWTPrincipalReference(user);
	wt.part.WTPart partBefore =getPartByNumber(beforeNumber);
	partBefore = (WTPart) PersistenceHelper.manager.refresh(partBefore);
	setModifier(partBefore, uref);
    PersistenceServerHelper.manager.update(partBefore);



public static WTUser getUserByName(String name){
    	WTUser user = null;   
    	try {
    		QuerySpec qs = new QuerySpec(WTUser.class);
			SearchCondition sc = new SearchCondition(WTUser.class,WTUser.NAME, SearchCondition.EQUAL, name, false);
			qs.appendSearchCondition(sc);			
			
			QueryResult qr = PersistenceHelper.manager.find(qs);
			if (qr.hasMoreElements()){
				user = (WTUser)qr.nextElement();
			}
			
			if(user == null)
				user = OrganizationServicesHelper.manager.getUser(name);				
			
		} catch (Exception e) {
			e.printStackTrace();
		}
    	return user;
    }

/**
	 * Answer a part by for a given part number
	 * @param partNumber - the String object used as search criteria in the retrieval of WTPart  
	 * @return WTPart
	 */
	public static WTPart getPartByNumber(String partNumber){
		WTPart part = null;
		try{
			WTPartMaster partMaster = getPartMasterByNumber(partNumber);
			if(partMaster == null){
				return null;
			}
			QueryResult qr = VersionControlHelper.service.allIterationsOf((Master)partMaster);
			if (qr.hasMoreElements()){
				part = (WTPart)qr.nextElement();
			}
		}catch(Exception ex){
			ex.printStackTrace();
			System.out.println("TAPart.class Method=getPartByNumber,number is ="+partNumber+" Exception Message = " + ex.getMessage()); //Debug
		}
		return part;
	}

/**
	 * Answer a part by for a given part number
	 * @param partNumber - the String object used as search criteria in the retrieval of WTPart  
	 * @return WTPart
	 * 
	 */
	public static WTPartMaster getPartMasterByNumber(String partNumber){
		WTPartMaster partMaster = null;
		try{						
			QuerySpec qs = new QuerySpec(WTPartMaster.class);			
			SearchCondition sc = new
					SearchCondition(WTPartMaster.class, WTPartMaster.NUMBER, 
							SearchCondition.EQUAL,StringUtils.trim(partNumber),false);
			qs.appendSearchCondition(sc);
			QueryResult qr = PersistenceHelper.manager.find(qs);
			if (qr.hasMoreElements()){				
				partMaster = (WTPartMaster)qr.nextElement();
			}
		}catch(Exception e){
			e.printStackTrace();
			System.out.println("TAPart.class Method=getPartMasterByNumber Exception Message = " + e.getMessage()); //Debug
		}
		return partMaster;
	}

2、如果是修改了修改者屬性,還同時需要時間歷史記錄也同步修改的話
就需要另外的方式
方式1:給用戶添加到管理員羣組
給用戶添加到管理員羣組,修改完了後在把人從管理員羣組刪除
這種方案也不是百分百管用,比如你們系統裏面直接將管理員羣組的這個權限屏蔽了,
只有wcadmin纔可以改,哈哈,就只能用方式2

WTGroup admingroup = CSCPrincipal.getGroupByName("Administrators"); 
boolean  isMember = OrganizationServicesHelper.manager.isMember(admingroup, currentUser); 
if(!isMember) { 
	admingroup.addMember(currentUser); 
}
//執行業務邏輯,完事後移除管理員組成員
if(!isMember) { 
	admingroup.removeMember(currentUser); 
}
方式2:給用戶動態賦權,操作完後回收權限,這種方案的侷限性是如果修改的對象版本過多,則耗時較長
配以配合其他方式解決,如直接給用戶一個modify identity full control的權限.
		AccessPermissionSet accessSet = new AccessPermissionSet();
     	accessSet.add(AccessPermission.CREATE);
     	accessSet.add(AccessPermission.MODIFY);
     	accessSet.add(AccessPermission.READ);
     	accessSet.add(AccessPermission.MODIFY_IDENTITY);
     	accessSet.add(AccessPermission.MODIFY_CONTENT);
     	AccessControlServerHelper.manager.addPermissions((AdHocControlled) partBefore, 
     			WTPrincipalReference.newWTPrincipalReference(currentUser), accessSet, 
     			AdHocAccessKey.WNC_ACCESS_CONTROL, partBefore.getPersistInfo().getObjectIdentifier().getId());
     	//執行業務邏輯,完事後回收動態權限
     	 //創建完成後,移除權限
         AccessControlServerHelper.manager.removePermissions((AdHocControlled) partBefore, 
           		WTPrincipalReference.newWTPrincipalReference(currentUser), accessSet, 
           		AdHocAccessKey.WNC_ACCESS_CONTROL, partBefore.getPersistInfo().getObjectIdentifier().getId());

3、簡單粗暴的修改數據庫記錄

 public void setCreator(WTChangeRequest2 cr2, WTUser user) throws Exception {
        long userId = getOid(user).getId();
        long ecrId = getOid(cr2).getId();
        StringBuffer updateSQL = new StringBuffer("UPDATE WTCHANGEREQUEST2 SET classnamekeyD2iterationInfo = '").append(WTUser.class.getName()).append("'");
        updateSQL.append(", idA3D2iterationInfo =").append(userId);
        updateSQL.append(" WHERE IDA2A2 =").append(ecrId);
        logger.debug("setCreator : " + updateSQL.toString());
        statement.executeQuery(updateSQL.toString());
    }

    public void setModifier(WTChangeRequest2 cr2, WTUser user) throws Exception {
        long userId = getOid(user).getId();
        long ecrId = getOid(cr2).getId();
        StringBuffer updateSQL = new StringBuffer("UPDATE WTCHANGEREQUEST2 SET classnamekeyB2iterationInfo = '").append(WTUser.class.getName()).append("'");
        updateSQL.append(", idA3B2iterationInfo =").append(userId);
        updateSQL.append(" WHERE IDA2A2 =").append(ecrId);
        statement.execute(updateSQL.toString());
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章