|
@@ -19,11 +19,11 @@ interface IrcClient {
|
19
|
19
|
val channelState: ChannelStateMap
|
20
|
20
|
val userState: UserState
|
21
|
21
|
|
|
22
|
+ fun onEvent(handler: (IrcEvent) -> Unit)
|
|
23
|
+
|
22
|
24
|
val caseMapping: CaseMapping
|
23
|
25
|
get() = serverState.features[ServerFeature.ServerCaseMapping] ?: CaseMapping.Rfc
|
24
|
26
|
|
25
|
|
- var eventHandler: EventHandler?
|
26
|
|
-
|
27
|
27
|
fun isLocalUser(user: User): Boolean = caseMapping.areEquivalent(user.nickname, serverState.localNickname)
|
28
|
28
|
|
29
|
29
|
}
|
|
@@ -39,18 +39,12 @@ class IrcClientImpl(private val server: Server, private val profile: Profile) :
|
39
|
39
|
override val channelState = ChannelStateMap { caseMapping }
|
40
|
40
|
override val userState = UserState { caseMapping }
|
41
|
41
|
|
42
|
|
- override var eventHandler: EventHandler? = null
|
43
|
|
- set(value) {
|
44
|
|
- field?.let { messageHandler.handlers.remove(it) }
|
45
|
|
- field = value
|
46
|
|
- field?.let { messageHandler.handlers.add(it) }
|
47
|
|
- }
|
48
|
|
-
|
49
|
42
|
private val messageHandler = MessageHandler(messageProcessors.toList(), eventHandlers.toMutableList())
|
50
|
43
|
|
51
|
44
|
private val parser = MessageParser()
|
52
|
45
|
private var socket: LineBufferedSocket? = null
|
53
|
46
|
|
|
47
|
+ // TODO: It would be cleaner if this didn't suspend but returned immediately
|
54
|
48
|
override suspend fun send(message: String) {
|
55
|
49
|
socket?.sendLine(message)
|
56
|
50
|
}
|
|
@@ -77,28 +71,32 @@ class IrcClientImpl(private val server: Server, private val profile: Profile) :
|
77
|
71
|
socket?.disconnect()
|
78
|
72
|
}
|
79
|
73
|
|
80
|
|
- companion object {
|
81
|
|
- @JvmStatic
|
82
|
|
- fun main(args: Array<String>) {
|
83
|
|
- val rootLogger = LogManager.getLogManager().getLogger("")
|
84
|
|
- rootLogger.level = Level.FINEST
|
85
|
|
- for (h in rootLogger.handlers) {
|
86
|
|
- h.level = Level.FINEST
|
|
74
|
+ override fun onEvent(handler: (IrcEvent) -> Unit) {
|
|
75
|
+ messageHandler.handlers.add(object : EventHandler {
|
|
76
|
+ override suspend fun processEvent(client: IrcClient, event: IrcEvent) {
|
|
77
|
+ handler(event)
|
87
|
78
|
}
|
|
79
|
+ })
|
|
80
|
+ }
|
|
81
|
+}
|
|
82
|
+
|
|
83
|
+fun main() {
|
|
84
|
+ val rootLogger = LogManager.getLogManager().getLogger("")
|
|
85
|
+ rootLogger.level = Level.FINEST
|
|
86
|
+ for (h in rootLogger.handlers) {
|
|
87
|
+ h.level = Level.FINEST
|
|
88
|
+ }
|
88
|
89
|
|
|
90
|
+ runBlocking {
|
|
91
|
+ val client = IrcClientImpl(Server("testnet.inspircd.org", 6667), Profile("KtIrc", "Kotlin!", "kotlin"))
|
|
92
|
+ client.onEvent { event ->
|
89
|
93
|
runBlocking {
|
90
|
|
- val client = IrcClientImpl(Server("testnet.inspircd.org", 6667), Profile("KtIrc", "Kotlin!", "kotlin"))
|
91
|
|
- client.eventHandler = object : EventHandler {
|
92
|
|
- override suspend fun processEvent(client: IrcClient, event: IrcEvent) {
|
93
|
|
- when (event) {
|
94
|
|
- is ServerWelcome -> client.send(joinMessage("#ktirc"))
|
95
|
|
- is MessageReceived -> if (event.message == "!test") client.send(privmsgMessage(event.target, "Test successful!"))
|
96
|
|
- }
|
97
|
|
- }
|
|
94
|
+ when (event) {
|
|
95
|
+ is ServerWelcome -> client.send(joinMessage("#ktirc"))
|
|
96
|
+ is MessageReceived -> if (event.message == "!test") client.send(privmsgMessage(event.target, "Test successful!"))
|
98
|
97
|
}
|
99
|
|
- client.connect()
|
100
|
98
|
}
|
101
|
99
|
}
|
|
100
|
+ client.connect()
|
102
|
101
|
}
|
103
|
|
-
|
104
|
102
|
}
|