Class RequestNumQueries
- java.lang.Object
-
- de.bsvrz.dav.daf.main.impl.archive.request.RequestNumQueries
-
- All Implemented Interfaces:
ArchiveNumQueriesResult,ArchiveQueryResult
public class RequestNumQueries extends java.lang.Object implements ArchiveNumQueriesResult
Diese Klasse stellt ein Objekt zur Verfügung, über das eine Anfrage nach der Anzahl möglichen Archivanfragen (pro Applikation) gestartet werden kann. Diese Klasse wird von der KlasseStreamedArchiveRequesterbenutzt.
-
-
Constructor Summary
Constructors Constructor Description RequestNumQueries(ArchiveQueryID archiveRequestID, StreamedArchiveRequester streamedArchiveRequester, short defaultSimulationVariant)
-
Method Summary
Modifier and Type Method Description voidaborted(java.lang.String errorMessage)Setzt eine Fehlermeldung und bewirkt, dass nicht weiter auf eine Antwort vom Archivsystem gewartet wird.voidarchiveResponse(Data data)Diese Methode wird aufgerufen, wenn die Antwort des Archivsystems empfangen wurde.ArchiveQueryIDgetArchiveRequestID()intgetCurrentlyUsedQueries()Gibt die (aus Sicht des Archivsystems) aktuelle Anzahl der derzeit aktiven Archivanfragen dieser Applikation zurück.java.lang.StringgetErrorMessage()Diese Methode liefert einen String mit der Fehlermeldung, die dazu geführt hat das die Informationsanfrage nicht ausgeführt werden konnte.intgetMaximumArchiveQueriesPerApplication()Gibt die im Archivsystem fest eingestellte maximale Anzahl an gleichzeitigen Archivanfragen pro Applikation zurück.intgetRemainingQueries()Gibt die (aus Sicht des Archivsystems) aktuelle Anzahl der noch möglichen gleichzeitigen Archivanfragen dieser Applikation zurück.booleanisRequestSuccessful()Diese Methode ist blockierend, bis die Antwort des Archivs vorliegt.voidsendRequestInfo()Diese Methode verschickt eine Archivinfoanfrage an das entsprechende Archivsystem und meldet sich wieder als Sender ab.
-
-
-
Constructor Detail
-
RequestNumQueries
public RequestNumQueries(ArchiveQueryID archiveRequestID, StreamedArchiveRequester streamedArchiveRequester, short defaultSimulationVariant)
-
-
Method Detail
-
getMaximumArchiveQueriesPerApplication
public int getMaximumArchiveQueriesPerApplication()
Description copied from interface:ArchiveNumQueriesResultGibt die im Archivsystem fest eingestellte maximale Anzahl an gleichzeitigen Archivanfragen pro Applikation zurück.- Specified by:
getMaximumArchiveQueriesPerApplicationin interfaceArchiveNumQueriesResult- Returns:
- maximale Anzahl an gleichzeitigen Archivanfragen pro Applikation
-
getCurrentlyUsedQueries
public int getCurrentlyUsedQueries()
Description copied from interface:ArchiveNumQueriesResultGibt die (aus Sicht des Archivsystems) aktuelle Anzahl der derzeit aktiven Archivanfragen dieser Applikation zurück.- Specified by:
getCurrentlyUsedQueriesin interfaceArchiveNumQueriesResult- Returns:
- Aktuell verwendete Anzahl an Archivanfragen
-
getRemainingQueries
public int getRemainingQueries()
Description copied from interface:ArchiveNumQueriesResultGibt die (aus Sicht des Archivsystems) aktuelle Anzahl der noch möglichen gleichzeitigen Archivanfragen dieser Applikation zurück. Theoretisch kann eine Applikation noch die zurückgegebene Anzahl an Archivanfragen stellen, ohne dass es zu Problemen kommt. Aufgrund von Timing-Problemen kann das aber nicht immer garantiert werden.- Specified by:
getRemainingQueriesin interfaceArchiveNumQueriesResult- Returns:
- Noch unbenutzes Kontigent an möglichen Archivanfragen für diese Applikation.
-
isRequestSuccessful
public boolean isRequestSuccessful() throws java.lang.InterruptedExceptionDiese Methode ist blockierend, bis die Antwort des Archivs vorliegt.- Specified by:
isRequestSuccessfulin interfaceArchiveQueryResult- Returns:
- true = Die Anfrage konnte fehlerfrei bearbeitet werden; false = Während der Bearbeitung der Anfrage kam es
zu einem Fehler, dieser kann mit
getErrorMessageangezeigt werden - Throws:
java.lang.InterruptedException- Der Thread, der den Auftrag bearbeitet, wurde abgebrochen
-
getErrorMessage
public java.lang.String getErrorMessage() throws java.lang.InterruptedExceptionDiese Methode liefert einen String mit der Fehlermeldung, die dazu geführt hat das die Informationsanfrage nicht ausgeführt werden konnte. Dieser Aufruf blockiert solange, bis ein Ergebnis des Archivsystems vorliegt.- Specified by:
getErrorMessagein interfaceArchiveQueryResult- Returns:
- String mit einer Fehlermeldung
- Throws:
java.lang.InterruptedException- Der Thread, der den Auftrag bearbeitet, wurde abgebrochen
-
aborted
public void aborted(java.lang.String errorMessage)
Description copied from interface:ArchiveQueryResultSetzt eine Fehlermeldung und bewirkt, dass nicht weiter auf eine Antwort vom Archivsystem gewartet wird.- Specified by:
abortedin interfaceArchiveQueryResult- Parameters:
errorMessage- Fehlermeldung, mit der die Anfrage terminiert wird.
-
sendRequestInfo
public void sendRequestInfo()
Diese Methode verschickt eine Archivinfoanfrage an das entsprechende Archivsystem und meldet sich wieder als Sender ab.
-
archiveResponse
public void archiveResponse(Data data)
Diese Methode wird aufgerufen, wenn die Antwort des Archivsystems empfangen wurde. Die Antwort wird analysiert und die betreffenden Objekte zur Verfügung gestellt, wartende Threads werden benachrichtigt.
-
getArchiveRequestID
public ArchiveQueryID getArchiveRequestID()
- Returns:
- Eindeutige Identifikation der Archivanfrage (RequestInfo in diesem Fall)
-
-