forked from GitHub/dbot
fix ~mergeusers, create getChannel and resolveChannel distinction [#548]
This commit is contained in:
parent
06053b9e17
commit
9d6b2cc3e1
@ -33,7 +33,7 @@ var api = function(dbot) {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
'getChannel': function(server, channelName, callback) {
|
'resolveChannel': function(server, channelName, callback) {
|
||||||
var channel = false;
|
var channel = false;
|
||||||
this.db.search('channel_users', {
|
this.db.search('channel_users', {
|
||||||
'server': server,
|
'server': server,
|
||||||
@ -47,6 +47,13 @@ var api = function(dbot) {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'getChannel': function(uuid, callback) {
|
||||||
|
this.db.read('channel_users', uuid, function(err, channel) {
|
||||||
|
if(err) channel = false;
|
||||||
|
callback(channel);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
'getRandomChannelUser': function(server, channel, callback) {
|
'getRandomChannelUser': function(server, channel, callback) {
|
||||||
var channel;
|
var channel;
|
||||||
this.db.search('channel_users', {
|
this.db.search('channel_users', {
|
||||||
|
@ -98,12 +98,11 @@ var commands = function(dbot) {
|
|||||||
if(oldUser) {
|
if(oldUser) {
|
||||||
user.aliases.push(oldUser.primaryNick);
|
user.aliases.push(oldUser.primaryNick);
|
||||||
user.aliases = _.union(user.aliases, oldUser.aliases);
|
user.aliases = _.union(user.aliases, oldUser.aliases);
|
||||||
this.internalAPI.mergeChannelUsers(event.server, oldUser, user);
|
this.internalAPI.mergeChannelUsers(oldUser, user);
|
||||||
this.db.del('users', oldUser.id, function(err) {
|
this.db.del('users', oldUser.id, function(err) {
|
||||||
if(!err) {
|
if(!err) {
|
||||||
this.db.save('users', user.id, user, function(err) {
|
this.db.save('users', user.id, user, function(err) {
|
||||||
if(!err) {
|
if(!err) {
|
||||||
this.internalAPI.mergeChannelUsers(event.server, secondaryUser, primaryUser);
|
|
||||||
event.reply(dbot.t('merged_users', {
|
event.reply(dbot.t('merged_users', {
|
||||||
'old_user': secondaryUser,
|
'old_user': secondaryUser,
|
||||||
'new_user': primaryUser
|
'new_user': primaryUser
|
||||||
|
@ -120,10 +120,10 @@ var users = function(dbot) {
|
|||||||
});
|
});
|
||||||
}.bind(this),
|
}.bind(this),
|
||||||
|
|
||||||
'mergeChannelUsers': function(server, oldUser, newUser) {
|
'mergeChannelUsers': function(oldUser, newUser) {
|
||||||
newUser.channels = _.union(oldUser.channels, newUser.channels);
|
newUser.channels = _.union(oldUser.channels, newUser.channels);
|
||||||
_.each(newUser.channels, function(name) {
|
_.each(newUser.channels, function(uuid) {
|
||||||
this.api.getChannel(server, name, function(channel) {
|
this.api.getChannel(uuid, function(channel) {
|
||||||
if(_.include(channel.users, oldUser.id)) {
|
if(_.include(channel.users, oldUser.id)) {
|
||||||
channel.users = _.without(channel.users, oldUser.id);
|
channel.users = _.without(channel.users, oldUser.id);
|
||||||
}
|
}
|
||||||
@ -189,7 +189,7 @@ var users = function(dbot) {
|
|||||||
|
|
||||||
dbot.instance.addPreEmitHook(function(event, callback) {
|
dbot.instance.addPreEmitHook(function(event, callback) {
|
||||||
if(event.channel) {
|
if(event.channel) {
|
||||||
this.api.getChannel(event.server, event.channel.name, function(channel) {
|
this.api.resolveChannel(event.server, event.channel.name, function(channel) {
|
||||||
event.rChannel = channel;
|
event.rChannel = channel;
|
||||||
callback(false);
|
callback(false);
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user