Parse chat info and invite via chat id (more secure)
This commit is contained in:
parent
346971ee40
commit
d06964b6a5
@ -33,6 +33,20 @@ module.exports = (robot) ->
|
|||||||
callback (reply.split '\n')[1..-3]
|
callback (reply.split '\n')[1..-3]
|
||||||
client.end()
|
client.end()
|
||||||
|
|
||||||
|
# return an object with the known chat information
|
||||||
|
chat_info = (name, callback) ->
|
||||||
|
run_command "chat_info #{norm name}", (data) ->
|
||||||
|
match = data[0].match ///
|
||||||
|
Chat\ (\w+(\ ?\w+)*) # chat name
|
||||||
|
\ \(id\ (\d+)\) # chat id
|
||||||
|
///
|
||||||
|
chat =
|
||||||
|
name: match[1]
|
||||||
|
id: 'chat#'+match[3]
|
||||||
|
members: data[1..].map (i) -> (i.split ' invited')[0].replace /\t/g, ''
|
||||||
|
robot.logger.info 'parsed chat data: ' + JSON.stringify chat, null, 2
|
||||||
|
callback chat
|
||||||
|
|
||||||
# return an object with the known user information
|
# return an object with the known user information
|
||||||
user_info = (name, callback) ->
|
user_info = (name, callback) ->
|
||||||
run_command "user_info #{norm name}", (data) ->
|
run_command "user_info #{norm name}", (data) ->
|
||||||
@ -120,29 +134,30 @@ module.exports = (robot) ->
|
|||||||
denied = ['BZBZ ADMIN-NOT-DETECTED', 'BZBZ IS-NOT-AUTHORIZED', 'BZBZ ACCESS-DENIED']
|
denied = ['BZBZ ADMIN-NOT-DETECTED', 'BZBZ IS-NOT-AUTHORIZED', 'BZBZ ACCESS-DENIED']
|
||||||
nope = ['ahahah NO', 'mai sentito questo?', 'invita anche me magari']
|
nope = ['ahahah NO', 'mai sentito questo?', 'invita anche me magari']
|
||||||
ok = ['provvedo subito', 'ok', 'certo', 'va bene']
|
ok = ['provvedo subito', 'ok', 'certo', 'va bene']
|
||||||
done = ['fatto', 'ecco qui', 'ecco']
|
done = ['fatto', 'ecco qui', 'ecco fatto']
|
||||||
group_list (list) ->
|
|
||||||
chat = res.match[4]
|
|
||||||
user = res.message.user.name
|
|
||||||
if not chat in list
|
|
||||||
res.send res.random nope
|
|
||||||
return
|
|
||||||
if chat is process.env['ADMIN_ROOM_NAME']
|
|
||||||
res.send res.random denied
|
|
||||||
return
|
|
||||||
res.send res.random ok
|
|
||||||
|
|
||||||
norm = (x) -> x.replace /\ /g, '_'
|
|
||||||
|
|
||||||
run_command "chat_add_user #{norm chat} #{norm user}", (reply) ->
|
user = res.message.user
|
||||||
robot.logger.info "add user #{user} to chat #{chat}"
|
name = res.match[4]
|
||||||
robot.logger.info 'result: ' + reply[0]
|
admin_id = process.env['ADMIN_ROOM'].replace ':', '#'
|
||||||
err = (reply[0].split ' ')[-1..][0]
|
|
||||||
if err is 'SUCCESS'
|
chat_list (list) ->
|
||||||
res.send res.random done
|
if not name in list
|
||||||
else if err is 'USER_NOT_MUTUAL_CONTACT'
|
return res.send res.random nope
|
||||||
res.send 'aah, non posso: ho bisogno del tuo contatto'
|
chat_info name, (chat) ->
|
||||||
else if err is 'USER_ALREADY_PARTICIPANT'
|
if chat.id is admin_id
|
||||||
res.send 'ma sei già nel gruppo... [facepalm]'
|
return res.send res.random denied
|
||||||
else
|
if user.name in chat.members
|
||||||
res.send "non sono riuscito, c'è un errore: #{reply[0]}"
|
return res.send 'ma sei già nel gruppo... [facepalm]'
|
||||||
|
res.send res.random ok
|
||||||
|
|
||||||
|
run_command "chat_add_user #{chat.id} #{user.id}", (reply) ->
|
||||||
|
robot.logger.info "add user #{user.name} to chat #{chat.name}"
|
||||||
|
robot.logger.info 'result: ' + reply[0]
|
||||||
|
err = (reply[0].split ' ')[-1..][0]
|
||||||
|
if err is 'SUCCESS'
|
||||||
|
robot.messageRoom chat.id, res.random done
|
||||||
|
robot.messageRoom chat.id, 'benvento'
|
||||||
|
else if err is 'USER_NOT_MUTUAL_CONTACT'
|
||||||
|
res.send 'aah, non posso: ho bisogno del tuo contatto'
|
||||||
|
else
|
||||||
|
res.send "non sono riuscito, c'è un errore: #{reply[0]}"
|
||||||
|
Loading…
Reference in New Issue
Block a user