-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathConnectionController.rb
More file actions
208 lines (181 loc) · 5.82 KB
/
ConnectionController.rb
File metadata and controls
208 lines (181 loc) · 5.82 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
#require "eventmachine"
require "AppController"
require "lib/syme/SymeLib"
require "models/irc/Channel"
require "models/irc/Connection"
require "models/irc/Message"
require "models/irc/User"
class ConnectionController
ERROR_CODES = (400..599).map { |i| i.to_s }
attr_reader :model
# Runs in network thread!
def initialize(user, host, port = 6667, args = {})
name = args[:name] || host
chans = args[:channels] || []
@app = AppController.instance
@logger = @app.logger
frontend = @app.frontend_queue
@logger.info("Connecting...")
@conn = EventMachine::connect(host, port, SymeLib::Irc,
user.nick,
:channels => chans,
:logger => @logger,
:user => user.user,
:version => "Syme IRC 0.1dev")
frontend.invoke_later do
@model = Connection.new(self, host, user)
@app.conn_list.add_connection(@model)
end
# All errors
@conn.on ERROR_CODES do |event|
# TODO: Output error message
end
# Discover userhost
@conn.on :raw do |event|
user.user = @conn.user unless @conn.user.nil?
end
# MOTD
@conn.on :motd_start, :motd, :motd_end do |event|
frontend.invoke_later do
source = @model.get_user("*", event.source)
msg = Message.new(source, event.target, event.content, event.type)
@model.chat.add_message(msg)
end
end
# Join
on_frontend :join do |event|
if(event.source_nick == user.nick)
@model.add_channel(event.channel)
@logger.info("Joined #{event.channel}")
else
u = @model.get_user(event.source_nick, event.source_user)
@model.add_user(u, event.channel)
content = "#{u.nick} joined #{event.channel}"
@logger.info(content)
msg = Message.new(@model.get_user("*"), event.channel, content, type = :join)
@model.channels[event.channel]
@model.channels[event.channel].add_message(msg)
end
end
# Part
on_frontend :part do |event|
if(event.source_nick == user.nick)
# Left channel
@logger.info("Leaving...")
else
# Someone else left
u = @model.users[event.source_nick]
unless u.nil?
@model.delete_user(u, event.channel)
content = "#{u.nick} has left #{event.channel}"
@logger.info(content)
msg = Message.new(@model.get_user("*"), event.channel, content, type = :join)
@model.channels[event.channel]
@model.channels[event.channel].add_message(msg)
end
end
end
# Users
@conn.on :names_reply do |event|
frontend.invoke_later do
chat = @model.channels[event.channel]
unless chat.nil?
event.names.each do |name, mode|
u = @model.get_user(name)
case mode
when :o
chat.modes.o.push(u)
when :v
chat.modes.v.push(u)
end
@model.add_user(u, event.channel)
end
chat.modes_changed()
end
end
end
# Mode change
on_frontend :mode do |event|
chan = @model.channels[event.channel] if event.respond_to? :channel
unless chan.nil?
event.modes.each do |mode, set|
case mode
when :o, :v
u = @model.users[event.params[mode]]
unless u.nil?
if mode == :o
m = chan.modes.o
content = "operator status"
else
m = chan.modes.v
content = "voice"
end
if set
m.push(u)
content = "#{event.source_nick} gives #{content || mode} to #{u.nick}"
else
m.delete(u)
content = "#{event.source_nick} removes #{content|| mode} from #{u.nick}"
end
@logger.info(content)
msg = Message.new(@model.get_user("*"), event.channel, content, type = :mode)
@model.channels[event.channel]
@model.channels[event.channel].add_message(msg)
end
end
end
chan.modes_changed()
end
end
# Nick change
on_frontend :nick do |event|
source = @model.get_user(event.source_nick, event.source_user)
@model.rename_user(source.nick, event.target)
content = "#{event.source_nick} changed nickname to #{event.target}"
@logger.info(content)
msg = Message.new(@model.get_user("*"), event.target, content, type = :nick)
source.channels.each do |c|
c.add_message(msg)
end
end
# Topic
@conn.on :topic_is, :no_topic do |event|
frontend.invoke_later do
@model.channels[event.channel].topic = event.topic
end
end
# Messages
@conn.on :privmsg do |event|
#target = @model.users[event.target] unless event.target.nil?
if event.respond_to? :channel
# Channel message
frontend.invoke_later do
@model.users[event.source_user]
source = @model.get_user(event.source_nick, event.source_user)
msg = Message.new(source, event.target, event.content, type = nil)
@model.channels[event.channel]
@model.channels[event.channel].add_message(msg)
end
else
# TODO: Private chat
frontend.invoke_later do
#@model.privates[event.source]
#@model.privates[event.source].add_message(msg)
end
end
end
end
def on_frontend(evt, &blk)
@conn.on evt do |event|
@app.frontend_queue.invoke_later do
blk.call(event)
end
end
end
def say(msg)
@conn.say(msg.target, msg.content)# if @model.channels.has_key? msg.target
end
def quit()
@conn.quit()
end
end