Project

General

Profile

« Previous | Next » 

Revision 9997

Added by Jing Tao over 8 years ago

Add the code to expand the rights holder if it is a group.

View differences:

src/edu/ucsb/nceas/metacat/dataone/D1NodeService.java
72 72
import org.dataone.service.types.v1.Identifier;
73 73
import org.dataone.service.types.v1.ObjectFormatIdentifier;
74 74
import org.dataone.service.types.v1.ObjectList;
75
import org.dataone.service.types.v1.SubjectInfo;
75 76
import org.dataone.service.types.v2.Log;
76 77
import org.dataone.service.types.v2.Node;
77 78
import org.dataone.service.types.v2.OptionList;
......
1147 1148
   * 1. Owner can have any permission.
1148 1149
   * 2. Access table allow the user has the permission
1149 1150
   */
1150
  public static boolean userHasPermission(Session userSession, Identifier pid, Permission permission ) throws NotFound{
1151
  public static boolean userHasPermission(Session userSession, Identifier pid, Permission permission ) throws NotFound, ServiceFailure, NotImplemented, InvalidRequest, InvalidToken, NotAuthorized {
1151 1152
      boolean allowed = false;
1152 1153
      // permissions are hierarchical
1153 1154
      List<Permission> expandedPermissions = null;
......
1197 1198
          allowed = systemMetadata.getRightsHolder().equals(s);
1198 1199
          if (allowed) {
1199 1200
              return allowed;
1201
          } else {
1202
              //check if the rightHolder is a group name. If it is, any member of the group can be considered a the right holder.
1203
              allowed = expandRightsHolder(systemMetadata.getRightsHolder(), s);
1204
              if(allowed) {
1205
                  return allowed;
1206
              }
1200 1207
          }
1201 1208
      }    
1202 1209
      
......
1230 1237
      }
1231 1238
      return allowed;
1232 1239
  }
1240
  
1241
  
1242
  /**
1243
   * Check if the given userSession is the member of the right holder group (if the right holder is a group subject).
1244
   * If the right holder is not a group, it will be false of course.
1245
   * @param rightHolder the subject of the right holder.
1246
   * @param userSession the subject will be compared
1247
   * @return true if the user session is a member of the right holder group; false otherwise.
1248
 * @throws NotImplemented 
1249
 * @throws ServiceFailure 
1250
 * @throws NotAuthorized 
1251
 * @throws InvalidToken 
1252
 * @throws InvalidRequest 
1253
   */
1254
  public static boolean expandRightsHolder(Subject rightHolder, Subject userSession) throws ServiceFailure, NotImplemented, InvalidRequest, InvalidToken, NotAuthorized {
1255
      boolean is = false;
1256
      if(rightHolder != null && userSession != null && rightHolder.getValue() != null && !rightHolder.getValue().trim().equals("") && userSession.getValue() != null && !userSession.getValue().trim().equals("")) {
1257
          CNode cn = D1Client.getCN();
1258
          logMetacat.debug("D1NodeService.expandRightHolder - after getting the cn node and cn node is "+cn.getNodeBaseServiceUrl());
1259
          String query= rightHolder.getValue();
1260
          int start =0;
1261
          int count=-1;
1262
          String status = null;
1263
          Session session = null;
1264
          SubjectInfo subjects = cn.listSubjects(session, query, status, start, count);
1265
          if(subjects != null) {
1266
              logMetacat.debug("D1NodeService.expandRightHolder - search the subject "+query+" in the cn and the returned result is not null");
1267
              List<Group> groups = subjects.getGroupList();
1268
              if(groups != null) {
1269
                  logMetacat.debug("D1NodeService.expandRightHolder - search the subject "+query+" in the cn and the returned result does include groups and the size of groups is "+groups.size());
1270
                  for(Group group : groups) {
1271
                      //logMetacat.debug("D1NodeService.expandRightHolder - group has the subject "+group.getSubject().getValue());
1272
                      if(group != null && group.getSubject() != null && group.getSubject().equals(rightHolder)) {
1273
                          logMetacat.debug("D1NodeService.expandRightHolder - there is a group in the list having the subjecct "+group.getSubject().getValue()+" which matches the right holder's subject "+rightHolder.getValue());
1274
                          List<Subject> members = group.getHasMemberList();
1275
                          if(members != null ){
1276
                              logMetacat.debug("D1NodeService.expandRightHolder - the group "+group.getSubject().getValue()+" in the cn has members");
1277
                              for(Subject member : members) {
1278
                                  logMetacat.debug("D1NodeService.expandRightHolder - compare the member "+member.getValue()+" with the user "+userSession.getValue());
1279
                                  if(member.getValue() != null && !member.getValue().trim().equals("") && userSession.getValue() != null && member.getValue().equals(userSession.getValue())) {
1280
                                      logMetacat.debug("D1NodeService.expandRightHolder - Find it! The member "+member.getValue()+" in the group "+group.getSubject().getValue()+" matches the user "+userSession.getValue());
1281
                                      is = true;
1282
                                      return is;
1283
                                  }
1284
                              }
1285
                          }
1286
                          break;//we found the group but can't find the member matches the user. so break it.
1287
                      }
1288
                  }
1289
              } else {
1290
                  logMetacat.debug("D1NodeService.expandRightHolder - search the subject "+query+" in the cn and the returned result does NOT have a group");
1291
              }
1292
          } else {
1293
              logMetacat.debug("D1NodeService.expandRightHolder - search the subject "+query+" in the cn and the returned result is null");
1294
          }
1295
          if(!is) {
1296
              logMetacat.debug("D1NodeService.expandRightHolder - We can NOT find any member in the group "+query+" (if it is a group) matches the user "+userSession.getValue());
1297
          }
1298
      } else {
1299
          logMetacat.debug("D1NodeService.expandRightHolder - We can't determine if the use subject is a member of the right holder group since one of them is null or blank");
1300
      }
1301
     
1302
      return is;
1303
  }
1233 1304
  /*
1234 1305
   * parse a logEntry and get the relevant field from it
1235 1306
   * 
src/edu/ucsb/nceas/metacat/dataone/MNodeService.java
62 62
import javax.xml.transform.stream.StreamResult;
63 63

  
64 64
import org.apache.commons.io.IOUtils;
65
import org.apache.commons.lang.NotImplementedException;
65 66
import org.apache.log4j.Logger;
66 67
import org.dataone.client.v2.CNode;
67 68
import org.dataone.client.v2.itk.D1Client;
......
394 395
        // does the subject have WRITE ( == update) priveleges on the pid?
395 396
        //allowed = isAuthorized(session, pid, Permission.WRITE);
396 397
        //CN having the permission is allowed; user with the write permission and calling on the authoritative node is allowed.
397
        allowed = allowUpdating(session, pid, Permission.WRITE);
398
        try {
399
            allowed = allowUpdating(session, pid, Permission.WRITE);
400
        }   catch (NotFound e) {
401
            throw new NotFound("1280", "Can't determine if the client has the permission to update the object with id "+pid.getValue()+" since "+e.getDescription());
402
        } catch(ServiceFailure e) {
403
            throw new ServiceFailure("1310", "Can't determine if the client has the permission to update the object with id "+pid.getValue()+" since "+e.getDescription());
404
        } catch(NotAuthorized e) {
405
            throw new NotAuthorized("1200", "Can't determine if the client has the permission to update the object with id "+pid.getValue()+" since "+e.getDescription());
406
        } catch(NotImplemented e) {
407
            throw new NotImplemented("1201","Can't determine if the client has the permission to update he object with id "+pid.getValue()+" since "+e.getDescription());
408
        } catch(InvalidRequest e) {
409
            throw new InvalidRequest("1202", "Can't determine if the client has the permission to update the object with id "+pid.getValue()+" since "+e.getDescription());
410
        } catch(InvalidToken e) {
411
            throw new InvalidToken("1210", "Can't determine if the client has the permission to update the object with id "+pid.getValue()+" since "+e.getDescription());
412
        }
413
        
398 414
        if (allowed) {
399 415
        	
400 416
        	// check quality of SM
......
2584 2600
             }
2585 2601
         } catch (NotFound e) {
2586 2602
             throw new InvalidRequest("4869", "Can't determine if the client has the permission to update the system metacat of the object with id "+pid.getValue()+" since "+e.getDescription());
2603
         } catch(ServiceFailure e) {
2604
             throw new ServiceFailure("4868", "Can't determine if the client has the permission to update the system metacat of the object with id "+pid.getValue()+" since "+e.getDescription());
2605
         } catch(NotAuthorized e) {
2606
             throw new NotAuthorized("4861", "Can't determine if the client has the permission to update the system metacat of the object with id "+pid.getValue()+" since "+e.getDescription());
2607
         } catch(NotImplemented e) {
2608
             throw new NotImplemented("4866","Can't determine if the client has the permission to update the system metacat of the object with id "+pid.getValue()+" since "+e.getDescription());
2609
         } catch(InvalidRequest e) {
2610
             throw new InvalidRequest("4869", "Can't determine if the client has the permission to update the system metacat of the object with id "+pid.getValue()+" since "+e.getDescription());
2611
         } catch(InvalidToken e) {
2612
             throw new InvalidToken("4957", "Can't determine if the client has the permission to update the system metacat of the object with id "+pid.getValue()+" since "+e.getDescription());
2587 2613
         }
2588 2614
         
2589 2615
     }
......
2680 2706
     * 2. If it is not a cn object, the client should have approperate permission and it should also happen on the authorative node.
2681 2707
     * 3. If it's the authoritative node, the MN Admin Subject is allowed.
2682 2708
     */
2683
    private boolean allowUpdating(Session session, Identifier pid, Permission permission) throws NotAuthorized, NotFound, InvalidRequest {
2709
    private boolean allowUpdating(Session session, Identifier pid, Permission permission) throws NotAuthorized, NotFound, InvalidRequest, ServiceFailure, NotImplemented, InvalidToken {
2684 2710
        boolean allow = false;
2685 2711
        
2686 2712
        if( isCNAdmin (session) ) {

Also available in: Unified diff