PreparedStatement pStmt = null;
ResultSet rset = null;
try
{
con.setAutoCommit(false);
QueryManager qManager = QueryManager.getInstance();
/* Check if there is any ROLE with same name */
String sql;
sql = qManager.getDuplicateRoleUpdateQuery(dbType);
pStmt = con.prepareStatement( sql );
pStmt.setString( 1, roleVO.getId() );
pStmt.setString( 2, roleVO.getRoleName() );
log.debug("SQL="+sql);
log.debug("ID="+roleVO.getId()+" || "+roleVO.getRoleName());
rset = pStmt.executeQuery();
if( rset.next() ){
if(rset.getInt(1)>0){
DAOException daox = new DAOException ("Database Error");
daox.setMessageKey(IErrorMessageKeys.KEY_ERROR_DUPLICATE_ROLE);
throw daox;
}
}
sql = qManager.getUpdateRole(dbType);
log.debug(sql);
pStmt = con.prepareStatement( sql );
pStmt.setString( 1, roleVO.getRoleName() );
pStmt.setString( 2, roleVO.getRoleDesc() );
pStmt.setString( 3, roleVO.getId());
pStmt.executeUpdate();
this.createSearchContent(con, dbType, roleVO, "TBL_ROLE", "ROLE_ID" ) ;
//first delete old groups
sql = qManager.getDeleteRoleGroupQuery(dbType);
pStmt = con.prepareStatement( sql );
pStmt.setString( 1, roleVO.getId());
pStmt.executeUpdate();
String[] groupIds = EEMSUtil.convertToArray(roleVO.getGroupNames(),IConstants.EEMS_DELIMITER);
if(groupIds!=null)
{
sql = qManager.getFetchRoleGroupQuery(dbType);
pStmt = con.prepareStatement( sql );
log.debug(sql);
for (int i=0; i<groupIds.length;i++)
{
if(groupIds[i]!= null)
{
log.debug("GROUPSID " + groupIds[i]);
log.debug("role id "+roleVO.getId());
pStmt.setString( 1, groupIds[i].trim() );
pStmt.setString( 2, roleVO.getId() );
pStmt.executeUpdate();
log.debug("ROLE-GROUP added" + i);
}
}
}
//first delete old privilege
sql = qManager.getDelRolePrivilegeQuery(dbType);
pStmt = con.prepareStatement( sql );
pStmt.setString( 1, roleVO.getId());
pStmt.executeUpdate();
/* Privilege */
String[] privilegeIds = EEMSUtil.convertToArray(roleVO.getPrivilegeNames(),IConstants.EEMS_DELIMITER);
if(groupIds!=null)
{
sql = qManager.getRolePrivilegeQuery(dbType);
pStmt = con.prepareStatement( sql );
log.debug(sql);
for (int i=0; i<privilegeIds.length;i++)
{