修改對象的修改者要看業務場景:
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());
}