projects
/
xudocci.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Expose connection uptime
[xudocci.git]
/
src
/
main
/
java
/
net
/
pterodactylus
/
irc
/
DefaultConnection.java
diff --git
a/src/main/java/net/pterodactylus/irc/DefaultConnection.java
b/src/main/java/net/pterodactylus/irc/DefaultConnection.java
index
8fe4c4b
..
876aefb
100644
(file)
--- a/
src/main/java/net/pterodactylus/irc/DefaultConnection.java
+++ b/
src/main/java/net/pterodactylus/irc/DefaultConnection.java
@@
-30,11
+30,14
@@
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.net.Socket;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.net.Socket;
+import java.time.Duration;
+import java.time.Instant;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;
+import java.util.concurrent.atomic.AtomicReference;
import javax.net.SocketFactory;
import javax.net.SocketFactory;
@@
-120,6
+123,7
@@
public class DefaultConnection extends AbstractExecutionThreadService implements
/** Whether the connection has already been established. */
private final AtomicBoolean established = new AtomicBoolean();
/** Whether the connection has already been established. */
private final AtomicBoolean established = new AtomicBoolean();
+ private final AtomicReference<Instant> connectionTime = new AtomicReference<>();
/**
* Creates a new connection.
/**
* Creates a new connection.
@@
-230,6
+234,13
@@
public class DefaultConnection extends AbstractExecutionThreadService implements
}
}
}
}
+ @Override
+ public java.util.Optional<Duration> getUptime() {
+ return established.get() ?
+ java.util.Optional.of(Duration.between(connectionTime.get(), Instant.now())) :
+ java.util.Optional.<Duration>empty();
+ }
+
//
// ABSTRACTEXECUTIONTHREADSERVICE METHODS
//
//
// ABSTRACTEXECUTIONTHREADSERVICE METHODS
//
@@
-358,6
+369,7
@@
public class DefaultConnection extends AbstractExecutionThreadService implements
@Subscribe
public void connectionEstablished(ConnectionEstablished connectionEstablished) {
if (connectionEstablished.connection() == this) {
@Subscribe
public void connectionEstablished(ConnectionEstablished connectionEstablished) {
if (connectionEstablished.connection() == this) {
+ connectionTime.set(Instant.now());
established.set(true);
}
}
established.set(true);
}
}