Revision 6476
Added by Matt Jones over 13 years ago
src/edu/ucsb/nceas/metacat/dataone/MNodeService.java | ||
---|---|---|
27 | 27 |
import java.io.InputStream; |
28 | 28 |
import java.security.NoSuchAlgorithmException; |
29 | 29 |
import java.sql.SQLException; |
30 |
import java.text.SimpleDateFormat; |
|
31 | 30 |
import java.util.Date; |
32 | 31 |
import java.util.List; |
33 | 32 |
import java.util.Timer; |
... | ... | |
36 | 35 |
import org.apache.log4j.Logger; |
37 | 36 |
import org.dataone.client.D1Client; |
38 | 37 |
import org.dataone.client.MNode; |
39 |
import org.dataone.service.util.Constants; |
|
40 | 38 |
import org.dataone.service.exceptions.IdentifierNotUnique; |
41 | 39 |
import org.dataone.service.exceptions.InsufficientResources; |
42 | 40 |
import org.dataone.service.exceptions.InvalidRequest; |
... | ... | |
78 | 76 |
import org.dataone.service.types.v1.Synchronization; |
79 | 77 |
import org.dataone.service.types.v1.SystemMetadata; |
80 | 78 |
import org.dataone.service.types.v1.util.ChecksumUtil; |
79 |
import org.dataone.service.util.Constants; |
|
81 | 80 |
|
82 | 81 |
import edu.ucsb.nceas.metacat.DocumentImpl; |
83 | 82 |
import edu.ucsb.nceas.metacat.EventLog; |
... | ... | |
88 | 87 |
import edu.ucsb.nceas.metacat.database.DBConnection; |
89 | 88 |
import edu.ucsb.nceas.metacat.database.DBConnectionPool; |
90 | 89 |
import edu.ucsb.nceas.metacat.properties.PropertyService; |
91 |
import edu.ucsb.nceas.metacat.util.SystemUtil; |
|
92 | 90 |
import edu.ucsb.nceas.utilities.PropertyNotFoundException; |
93 | 91 |
|
94 | 92 |
/** |
... | ... | |
591 | 589 |
} |
592 | 590 |
|
593 | 591 |
/** |
594 |
* Retrieve the list of objects present on the MN that match the calling parameters
|
|
592 |
* Return a description of the node's capabilities and services.
|
|
595 | 593 |
* |
596 | 594 |
* @return node - the technical capabilities of the Member Node |
597 | 595 |
* |
... | ... | |
605 | 603 |
|
606 | 604 |
String nodeName = null; |
607 | 605 |
String nodeId = null; |
608 |
String nodeUrl = null; |
|
609 | 606 |
String nodeDesc = null; |
610 |
String nodeType = null; |
|
607 |
String nodeTypeString = null; |
|
608 |
NodeType nodeType = null; |
|
611 | 609 |
String mnCoreServiceVersion = null; |
612 | 610 |
String mnReadServiceVersion = null; |
613 | 611 |
String mnAuthorizationServiceVersion = null; |
... | ... | |
626 | 624 |
// get the properties of the node based on configuration information |
627 | 625 |
nodeId = PropertyService.getProperty("dataone.memberNodeId"); |
628 | 626 |
nodeName = PropertyService.getProperty("dataone.nodeName"); |
629 |
nodeUrl = SystemUtil.getContextURL() + "/d1/"; |
|
630 | 627 |
nodeDesc = PropertyService.getProperty("dataone.nodeDescription"); |
631 |
nodeType = PropertyService.getProperty("dataone.nodeType"); |
|
628 |
nodeTypeString = PropertyService.getProperty("dataone.nodeType"); |
|
629 |
nodeType = NodeType.convert(nodeTypeString); |
|
632 | 630 |
nodeSynchronize = new Boolean(PropertyService.getProperty("dataone.nodeSynchronize")).booleanValue(); |
633 | 631 |
nodeReplicate = new Boolean(PropertyService.getProperty("dataone.nodeReplicate")).booleanValue(); |
634 | 632 |
|
... | ... | |
644 | 642 |
mnStorageServiceAvailable = new Boolean(PropertyService.getProperty("dataone.mnStorage.serviceAvailable")).booleanValue(); |
645 | 643 |
mnReplicationServiceAvailable = new Boolean(PropertyService.getProperty("dataone.mnReplication.serviceAvailable")).booleanValue(); |
646 | 644 |
|
647 |
} catch (PropertyNotFoundException pnfe) { |
|
648 |
logMetacat.error("MNodeService.getCapabilities(): " + "property not found: " + pnfe.getMessage()); |
|
645 |
// Set the properties of the node based on configuration information and |
|
646 |
// calls to current status methods |
|
647 |
Node node = new Node(); |
|
648 |
node.setBaseURL(metacatUrl + "/" + nodeTypeString); |
|
649 |
node.setDescription(nodeDesc); |
|
649 | 650 |
|
650 |
} |
|
651 |
// set the node's health information |
|
652 |
node.setState(NodeState.UP); |
|
653 |
|
|
654 |
// set the ping response to the current value |
|
655 |
Ping canPing = new Ping(); |
|
656 |
canPing.setSuccess(false); |
|
657 |
try { |
|
658 |
canPing.setSuccess(ping()); |
|
659 |
} catch (InsufficientResources e) { |
|
660 |
e.printStackTrace(); |
|
661 |
} catch (UnsupportedType e) { |
|
662 |
e.printStackTrace(); |
|
663 |
} |
|
664 |
node.setPing(canPing); |
|
651 | 665 |
|
652 |
// Set the properties of the node based on configuration information and |
|
653 |
// calls to current status methods |
|
654 |
Node node = new Node(); |
|
655 |
node.setBaseURL(metacatUrl + "/" + nodeType); |
|
656 |
node.setDescription(nodeDesc); |
|
666 |
NodeReference identifier = new NodeReference(); |
|
667 |
identifier.setValue(nodeId); |
|
668 |
node.setIdentifier(identifier); |
|
669 |
node.setName(nodeName); |
|
670 |
node.setReplicate(nodeReplicate); |
|
671 |
node.setSynchronize(nodeSynchronize); |
|
657 | 672 |
|
658 |
// set the node's health information |
|
659 |
NodeState state = NodeState.UP; |
|
660 |
node.setState(state); |
|
661 |
// set the ping response to the current value |
|
662 |
Ping canPing = new Ping(); |
|
663 |
canPing.setSuccess(false); |
|
664 |
try { |
|
665 |
canPing.setSuccess(ping()); |
|
666 |
} catch (InsufficientResources e) { |
|
667 |
e.printStackTrace(); |
|
673 |
// services: MNAuthorization, MNCore, MNRead, MNReplication, MNStorage |
|
674 |
Services services = new Services(); |
|
668 | 675 |
|
669 |
} catch (UnsupportedType e) { |
|
670 |
e.printStackTrace(); |
|
676 |
Service sMNCore = new Service(); |
|
677 |
sMNCore.setName("MNCore"); |
|
678 |
sMNCore.setVersion(mnCoreServiceVersion); |
|
679 |
sMNCore.setAvailable(mnCoreServiceAvailable); |
|
671 | 680 |
|
672 |
} |
|
673 |
node.setPing(canPing); |
|
681 |
Service sMNRead = new Service(); |
|
682 |
sMNRead.setName("MNRead"); |
|
683 |
sMNRead.setVersion(mnReadServiceVersion); |
|
684 |
sMNRead.setAvailable(mnReadServiceAvailable); |
|
674 | 685 |
|
675 |
NodeReference identifier = new NodeReference(); |
|
676 |
identifier.setValue(nodeId); |
|
677 |
node.setIdentifier(identifier); |
|
678 |
node.setName(nodeName + " -- WAR version WARVERSION"); |
|
679 |
node.setReplicate(new Boolean(nodeReplicate).booleanValue()); |
|
680 |
node.setSynchronize(new Boolean(nodeSynchronize).booleanValue()); |
|
686 |
Service sMNAuthorization = new Service(); |
|
687 |
sMNAuthorization.setName("MNAuthorization"); |
|
688 |
sMNAuthorization.setVersion(mnAuthorizationServiceVersion); |
|
689 |
sMNAuthorization.setAvailable(mnAuthorizationServiceAvailable); |
|
681 | 690 |
|
682 |
// services: MNAuthorization, MNCore, MNRead, MNReplication, MNStorage |
|
683 |
Services services = new Services(); |
|
691 |
Service sMNStorage = new Service(); |
|
692 |
sMNStorage.setName("MNStorage"); |
|
693 |
sMNStorage.setVersion(mnStorageServiceVersion); |
|
694 |
sMNStorage.setAvailable(mnStorageServiceAvailable); |
|
684 | 695 |
|
685 |
Service sMNCore = new Service();
|
|
686 |
sMNCore.setName("MNCore");
|
|
687 |
sMNCore.setVersion(mnCoreServiceVersion);
|
|
688 |
sMNCore.setAvailable(mnCoreServiceAvailable);
|
|
696 |
Service sMNReplication = new Service();
|
|
697 |
sMNReplication.setName("MNReplication");
|
|
698 |
sMNReplication.setVersion(mnReplicationServiceVersion);
|
|
699 |
sMNReplication.setAvailable(mnReplicationServiceAvailable);
|
|
689 | 700 |
|
690 |
Service sMNRead = new Service(); |
|
691 |
sMNRead.setName("MNRead"); |
|
692 |
sMNRead.setVersion(mnReadServiceVersion); |
|
693 |
sMNRead.setAvailable(mnReadServiceAvailable); |
|
701 |
services.addService(sMNRead); |
|
702 |
services.addService(sMNCore); |
|
703 |
services.addService(sMNAuthorization); |
|
704 |
services.addService(sMNStorage); |
|
705 |
services.addService(sMNReplication); |
|
706 |
node.setServices(services); |
|
694 | 707 |
|
695 |
Service sMNAuthorization = new Service(); |
|
696 |
sMNAuthorization.setName("MNAuthorization"); |
|
697 |
sMNAuthorization.setVersion(mnAuthorizationServiceVersion); |
|
698 |
sMNAuthorization.setAvailable(mnAuthorizationServiceAvailable); |
|
708 |
// TODO: Allow the metacat admin to determine the schedule |
|
709 |
// Set the schedule for synchronization |
|
710 |
Synchronization synchronization = new Synchronization(); |
|
711 |
Schedule schedule = new Schedule(); |
|
712 |
Date now = new Date(); |
|
713 |
schedule.setYear("*"); |
|
714 |
schedule.setMon("*"); |
|
715 |
schedule.setMday("*"); |
|
716 |
schedule.setWday("*"); |
|
717 |
schedule.setHour("*"); |
|
718 |
schedule.setMin("0,5,10,15,20,25,30,35,40,45,50,55"); |
|
719 |
schedule.setSec("*"); |
|
720 |
synchronization.setSchedule(schedule); |
|
721 |
synchronization.setLastHarvested(now); |
|
722 |
synchronization.setLastCompleteHarvest(now); |
|
723 |
node.setSynchronization(synchronization); |
|
699 | 724 |
|
700 |
Service sMNStorage = new Service(); |
|
701 |
sMNStorage.setName("MNStorage"); |
|
702 |
sMNStorage.setVersion(mnStorageServiceVersion); |
|
703 |
sMNStorage.setAvailable(mnStorageServiceAvailable); |
|
725 |
node.setType(nodeType); |
|
726 |
return node; |
|
704 | 727 |
|
705 |
Service sMNReplication = new Service(); |
|
706 |
sMNReplication.setName("MNReplication"); |
|
707 |
sMNReplication.setVersion(mnReplicationServiceVersion); |
|
708 |
sMNReplication.setAvailable(mnReplicationServiceAvailable); |
|
709 |
|
|
710 |
services.addService(sMNRead); |
|
711 |
services.addService(sMNCore); |
|
712 |
services.addService(sMNAuthorization); |
|
713 |
services.addService(sMNStorage); |
|
714 |
services.addService(sMNReplication); |
|
715 |
node.setServices(services); |
|
716 |
|
|
717 |
// TODO: Determine the synchronization info without mock values |
|
718 |
Synchronization synchronization = new Synchronization(); |
|
719 |
Schedule schedule = new Schedule(); |
|
720 |
Date now = new Date(); |
|
721 |
schedule.setYear(new SimpleDateFormat("yyyy").format(now)); |
|
722 |
schedule.setMon(new SimpleDateFormat("MM").format(now)); |
|
723 |
schedule.setMday(new SimpleDateFormat("dd").format(now)); |
|
724 |
schedule.setWday(new SimpleDateFormat("dd").format(now)); |
|
725 |
schedule.setHour(new SimpleDateFormat("HH").format(now)); |
|
726 |
schedule.setMin(new SimpleDateFormat("mm").format(now)); |
|
727 |
schedule.setSec(new SimpleDateFormat("ss").format(now)); |
|
728 |
synchronization.setSchedule(schedule); |
|
729 |
synchronization.setLastHarvested(now); |
|
730 |
synchronization.setLastCompleteHarvest(now); |
|
731 |
node.setSynchronization(synchronization); |
|
732 |
node.setSynchronize(false); |
|
733 |
node.setType(NodeType.MN); |
|
734 |
|
|
735 |
return node; |
|
728 |
} catch (PropertyNotFoundException pnfe) { |
|
729 |
String msg = "MNodeService.getCapabilities(): " + "property not found: " + pnfe.getMessage(); |
|
730 |
logMetacat.error(msg); |
|
731 |
throw new ServiceFailure("2162", msg); |
|
732 |
} |
|
736 | 733 |
} |
737 | 734 |
|
738 | 735 |
/** |
Also available in: Unified diff
Fix getCapabilities to properly throw ServiceFailure when properties can not be read, rather than failing with a log message. Fix properties in the Node object to reflect their correct values. Set the sync schedule properly to default to 5 minute intervals. Improve documentation.