Package depskys.clouds

Examples of depskys.clouds.CloudRequest


        for(int i = 1; i < allmetadata.size()+1; i++){
          namesToDelete[i] = allmetadata.get(i-1).getVersionFileId();
        }

        DepSkySCloudManager manager = getDriverManagerByDriverId(metadataReply.cloudId);
        CloudRequest r = new CloudRequest(DepSkySCloudManager.DEL_CONT,
            metadataReply.sequence, manager.driver.getSessionKey(),
            metadataReply.container,namesToDelete,metadataReply.reg,
            DepSkySManager.DELETE_ALL, false);
        manager.doRequest(r);

        return ;
      }

      //if is a read MAtching operation
      if(metadataReply.hashMatching != null){
        for(int i = 0; i < allmetadata.size(); i++){
          if(Arrays.equals(allmetadata.get(i).getAllDataHash(), metadataReply.hashMatching)){
            dm = allmetadata.get(i);
            datareplied = dm.getMetadata();
            if (datareplied.length() < 1) {
              throw new Exception("invalid metadata size received");
            }
            cont = allmetadata.size()+1;
          }
        }
        if(cont < allmetadata.size()+1 )
          throw new Exception("no matching version available");
      }else{ //if is a normal read (last version read)
        dm = allmetadata.getFirst();
        datareplied = dm.getMetadata();
        if (datareplied.length() < 1) {
          throw new Exception("invalid metadata size received");
        }
      }

      byte[] mdinfo = datareplied.getBytes();
      byte[] signature = dm.getsignature();
      Properties props = new Properties();
      props.load(new ByteArrayInputStream(mdinfo));
      //METADATA info
      String verNumber = props.getProperty("versionNumber");
      String verHash = props.getProperty("versionHash");
      String verValueFileId = props.getProperty("versionFileId");
      String verPVSSinfo = props.getProperty("versionPVSSinfo");
      String verECinfo = props.getProperty("versionECinfo");
      long versionfound = Long.parseLong(verNumber);
      //extract client id
      Long writerId = versionfound % MAX_CLIENTS;
      //metadata signature check
      if (!verifyMetadataSignature(writerId.intValue(), mdinfo, signature) ||
          !verifyMetadataSignature(writerId.intValue(), metadataInit, allMetadataSignature)) {
        //invalid signature
        System.out.println("...........................");
        throw new Exception("Signature verification failed for " + metadataReply);
      }
      //set the data unit to the protocol in use
      if ((verPVSSinfo != null || verECinfo != null)/* && metadataReply.reg.info == null*/) {
        if(verPVSSinfo != null && verECinfo == null){
          metadataReply.reg.setUsingSecSharing(true);
          metadataReply.reg.setPVSSinfo(verPVSSinfo.split(";"));
        }
        if(verECinfo != null && verPVSSinfo == null){
          metadataReply.reg.setUsingErsCodes(true);
          if(metadataReply.protoOp == DepSkySManager.READ_PROTO){
            metadataReply.reg.setErCodesReedSolMeta(verECinfo);             
          }
        } 
        if(verECinfo != null && verPVSSinfo !=null){
          metadataReply.reg.setUsingPVSS(true);
          metadataReply.reg.setPVSSinfo(verPVSSinfo.split(";"));
          if(metadataReply.protoOp == DepSkySManager.READ_PROTO){
            metadataReply.reg.setErCodesReedSolMeta(verECinfo)

          }
        }
      }
      long ts = versionfound - writerId;//remove client id from versionNumber
      metadataReply.setVersionNumber(ts + "");//version received
      metadataReply.setVersionHash(verHash);
      metadataReply.setValueFileId(verValueFileId);//added

      if(metadataReply.protoOp == DepSkySManager.ACL_PROTO){

        depskys.dataReceived(metadataReply);
        return;
      }

      if (metadataReply.protoOp == DepSkySManager.WRITE_PROTO) {
        if(metadataReply.cloudId.equals("cloud1")){
          cloud1.put(metadataReply.container, allmetadata);
        }else if(metadataReply.cloudId.equals("cloud2")){
          cloud2.put(metadataReply.container, allmetadata);
        }else if(metadataReply.cloudId.equals("cloud3")){
          cloud3.put(metadataReply.container, allmetadata);
        }else if(metadataReply.cloudId.equals("cloud4")){
          cloud4.put(metadataReply.container, allmetadata);
        }
        //        if (metadataReply.sequence < 0) {
        //          //System.out.println("read metadata, now sending write value...");
        //          DepSkySCloudManager manager = getDriverManagerByDriverId(metadataReply.cloudId);
        //          CloudRequest r = new CloudRequest(DepSkySCloudManager.NEW_DATA,
        //              metadataReply.sequence, manager.driver.getSessionKey(),
        //              metadataReply.container,
        //              metadataReply.reg.getGivenVersionValueDataFileName(ts + ""),
        //              depskys.testData, null,
        //              metadataReply.reg, metadataReply.protoOp, false,
        //              ts + "", verHash, metadataReply.allDataHash);
        //          r.setStartTime(metadataReply.startTime);
        //          r.setMetadataReceiveTime(metadataReply.metadataReceiveTime);
        //          manager.doRequest(r);//request valuedata file
        //          return;
        //        }
        depskys.dataReceived(metadataReply);
        return;
      }
      synchronized (this) {
        if (metadataReply.sequence == depskys.lastReadMetadataSequence) {
          if (depskys.lastMetadataReplies == null) {
            depskys.lastMetadataReplies = new ArrayList<CloudReply>();
          }
          depskys.lastMetadataReplies.add(metadataReply);
          metadataReply.reg.setCloudVersion(metadataReply.cloudId, ts);
          //System.out.println("IN:CLOUD VERSION " + ts + " for " + metadataReply.cloudId);
        }
        if (metadataReply.sequence >= 0
            && canReleaseAndReturn(metadataReply)) {
          //check release
          return;
        }
        if (!depskys.sendingParallelRequests() && depskys.sentOne) {
          //                    depskys.dataReceived(metadataReply);
        } else {
          depskys.sentOne = true;
          DepSkySCloudManager manager = getDriverManagerByDriverId(metadataReply.cloudId);
          CloudRequest r = new CloudRequest(DepSkySCloudManager.GET_DATA,
              metadataReply.sequence, manager.driver.getSessionKey(),
              metadataReply.container, verValueFileId, null, null,
              metadataReply.reg, metadataReply.protoOp, false,
              ts + "", verHash, null);
          r.setStartTime(metadataReply.startTime);
          r.setMetadataReceiveTime(metadataReply.metadataReceiveTime);
          manager.doRequest(r);//request valuedata file
        }
      }//end synch this

    } catch (Exception ex) {
View Full Code Here


      allmetadata.flush();
      allmetadata.close();

      //request to write new metadata file
      DepSkySCloudManager manager = getDriverManagerByDriverId(reply.cloudId);
      CloudRequest r = new CloudRequest(DepSkySCloudManager.NEW_DATA,
          reply.sequence, manager.driver.getSessionKey(),
          reply.container, reply.reg.regId + "metadata",
          allmetadata.toByteArray(), null, reply.reg,
          reply.protoOp, true, reply.hashMatching);
      r.setStartTime(reply.startTime);//added
      manager.doRequest(r);


    } catch (Exception ex) {
      ex.printStackTrace();
View Full Code Here

    int seq = getNextSequence();
    CloudRepliesControlSet rcs = new CloudRepliesControlSet(N, seq);
    replies.put(seq, rcs);
    for(int i = 0; i < 4; i++)
      manager.driversManagers[i].doRequest(
          new CloudRequest(DepSkySCloudManager.INIT_SESS, seq, null,
              null, null, null, new Properties(), null, -1, false, null));

    try {
      rcs.waitReplies.acquire();
    } catch (InterruptedException e) {
View Full Code Here

      int seq = getNextSequence();
      rcs = new CloudRepliesControlSet(N, seq);
      replies.put(seq, rcs);

      for (int i = 0; i < drivers.length; i++) {
        CloudRequest r = new CloudRequest(DepSkySCloudManager.NEW_DATA, sequence,
            drivers[i].getSessionKey(), reg.getContainerId(drivers[i].getDriverId()),
            filename, value, null,
            reg, DepSkySManager.WRITE_PROTO, true, null, null, null); //allmetadata no ultimo parametro
        manager.doRequest(drivers[i].getDriverId(), r);
      }
View Full Code Here

      int seq = getNextSequence();
      rcs = new CloudRepliesControlSet(N, seq);
      replies.put(seq, rcs);

      for (int i = 0; i < drivers.length; i++) {
        CloudRequest r = new CloudRequest(DepSkySCloudManager.GET_DATA, sequence,
            drivers[i].getSessionKey(), reg.getContainerId(drivers[i].getDriverId()),
            filename, null, null,
            reg, DepSkySManager.READ_PROTO, false, "true", null, null); //allmetadata no ultimo parametro
        manager.doRequest(drivers[i].getDriverId(), r);
View Full Code Here

      int seq = getNextSequence();
      rcs = new CloudRepliesControlSet(N, seq);
      replies.put(seq, rcs);

      for (int i = 0; i < drivers.length; i++) {
        CloudRequest r = new CloudRequest(DepSkySCloudManager.LIST, seq,
            drivers[i].getSessionKey(), reg.getContainerName(), prefix,
            null, null, reg, -1, true, null);
        manager.doRequest(drivers[i].getDriverId(), r);
      }
View Full Code Here

      int seq = getNextSequence();
      rcs = new CloudRepliesControlSet(N, seq);
      replies.put(seq, rcs);


      CloudRequest r = new CloudRequest(DepSkySCloudManager.GET_DATA, sequence,
          "sid", reg.getContainerId(driverId),
          filename, null, null,
          reg, DepSkySManager.READ_PROTO, false, "false", null, null);

      manager.doRequest(driverId, r);
View Full Code Here

      int seq = getNextSequence();
      rcs = new CloudRepliesControlSet(N, seq);
      replies.put(seq, rcs);

      for (int i = 0; i < drivers.length; i++) {
        CloudRequest r = new CloudRequest(DepSkySCloudManager.DEL_DATA, seq,
            drivers[i].getSessionKey(), reg.getContainerName(), name,
            null, null, reg, -1, true, null);
        manager.doRequest(drivers[i].getDriverId(), r);
      }
      rcs.waitReplies.acquire();
View Full Code Here

   */
  private void broadcastGetMetadata(int sequence,
      DepSkySDataUnit reg, int protoOp, byte[] hashMatching) {

    for (int i = 0; i < drivers.length; i++) {
      CloudRequest r = new CloudRequest(DepSkySCloudManager.GET_DATA, sequence,
          drivers[i].getSessionKey(), reg.getContainerName(), reg.getMetadataFileName(),
          null, null, reg, protoOp, true, hashMatching);

      if (reg.getContainerId(drivers[i].getDriverId()) == null) {
        reg.setContainerId(drivers[i].getDriverId(), reg.getContainerName());
View Full Code Here

   * NOT CURRENTLY USED
   */
  private void perDriverAclRequest(int sequence, DepSkySDataUnit reg, int protoOp, long version,
      int driverPosition, String permission, String canonicalId){

    CloudRequest r = new CloudRequest(DepSkySCloudManager.SET_ACL, sequence,
        drivers[driverPosition].getSessionKey(), reg.getContainerName(),
        reg.regId, reg, protoOp,
        permission, canonicalId);     
    manager.doRequest(drivers[driverPosition].getDriverId(), r);
  }
View Full Code Here

TOP

Related Classes of depskys.clouds.CloudRequest

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.