commit 15/10/2025
Network monitoring beres
This commit is contained in:
@@ -4,6 +4,7 @@ import com.fasterxml.jackson.databind.JsonNode
|
||||
import com.fasterxml.jackson.module.kotlin.jacksonObjectMapper
|
||||
import content.Category
|
||||
import content.Language
|
||||
import content.NetworkInformation
|
||||
import content.ScheduleDay
|
||||
import content.VoiceType
|
||||
import kotlinx.coroutines.CoroutineScope
|
||||
@@ -35,6 +36,7 @@ class Somecodes {
|
||||
val si = SystemInfo()
|
||||
val processor: CentralProcessor = si.hardware.processor
|
||||
val memory : GlobalMemory = si.hardware.memory
|
||||
val NetworkInfoMap = mutableMapOf<String, NetworkInformation>()
|
||||
|
||||
val datetimeformat1: DateTimeFormatter = DateTimeFormatter.ofPattern("dd/MM/yyyy HH:mm:ss")
|
||||
val dateformat1: DateTimeFormatter = DateTimeFormatter.ofPattern("dd/MM/yyyy")
|
||||
@@ -278,16 +280,43 @@ class Somecodes {
|
||||
, (usedMemory.toDouble() / totalMemory * 100))
|
||||
}
|
||||
|
||||
fun GetNetworkStatus(networkname: String) : String{
|
||||
fun GetNetworkStatus(cb : Consumer<List<NetworkInformation>>) {
|
||||
val networks: List<NetworkIF> = si.hardware.networkIFs.toList()
|
||||
//TODO cari network yang sesuai dengan networkname
|
||||
// networks.forEach { net ->
|
||||
//
|
||||
// println(net.name+" "+net.displayName+" ")
|
||||
// net.updateAttributes()
|
||||
// println("upload: ${SizetoHuman(net.bytesSent)} sent, download: ${SizetoHuman(net.bytesRecv)} received")
|
||||
// }
|
||||
return ""
|
||||
networks.forEach { net ->
|
||||
|
||||
if (net.ifOperStatus==NetworkIF.IfOperStatus.UP){
|
||||
if (net.iPv4addr.size>0 || net.iPv6addr.size>0){
|
||||
var ni = NetworkInfoMap[net.name]
|
||||
if (ni == null){
|
||||
ni = NetworkInformation(net.name, net.displayName, net.macaddr)
|
||||
NetworkInfoMap[net.name] = ni
|
||||
}
|
||||
ni.ipV4addr = net.iPv4addr.toMutableList()
|
||||
ni.ipV6addr = net.iPv6addr.toMutableList()
|
||||
ni.speed = net.speed
|
||||
ni.packetsSent = net.packetsSent
|
||||
ni.packetsRecv = net.packetsRecv
|
||||
if (ni.updateStamp==0L){
|
||||
ni.bytesSent = net.bytesSent
|
||||
ni.bytesRecv = net.bytesRecv
|
||||
ni.txSpeed = 0
|
||||
ni.rxSpeed = 0
|
||||
ni.updateStamp = System.currentTimeMillis()
|
||||
} else {
|
||||
// tx speed = (current bytesSent - previous bytesSent) / (current time - previous time) * 1000
|
||||
val currentTime = System.currentTimeMillis()
|
||||
ni.txSpeed = ((net.bytesSent - ni.bytesSent) * 1000 / (currentTime - ni.updateStamp))
|
||||
ni.rxSpeed = ((net.bytesRecv - ni.bytesRecv) * 1000 / (currentTime - ni.updateStamp))
|
||||
ni.bytesSent = net.bytesSent
|
||||
ni.bytesRecv = net.bytesRecv
|
||||
ni.updateStamp = currentTime
|
||||
}
|
||||
} else if (NetworkInfoMap.contains(net.name)) NetworkInfoMap.remove(net.name)
|
||||
} else if (NetworkInfoMap.contains(net.name)) NetworkInfoMap.remove(net.name)
|
||||
|
||||
|
||||
}
|
||||
cb.accept(NetworkInfoMap.values.toList())
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user