mirror of
https://github.com/reality/dbot.git
synced 2025-01-23 10:34:31 +01:00
Store channel users as per [#106]
This commit is contained in:
parent
5429740eef
commit
1785b89df0
@ -6,7 +6,7 @@ var users = function(dbot) {
|
|||||||
var knownUsers = dbot.db.knownUsers;
|
var knownUsers = dbot.db.knownUsers;
|
||||||
var getServerUsers = function(server) {
|
var getServerUsers = function(server) {
|
||||||
if(!knownUsers.hasOwnProperty(server)) {
|
if(!knownUsers.hasOwnProperty(server)) {
|
||||||
knownUsers[server] = { 'users': [], 'aliases': {} };
|
knownUsers[server] = { 'users': [], 'aliases': {}, 'channelUsers': {} };
|
||||||
}
|
}
|
||||||
return knownUsers[server];
|
return knownUsers[server];
|
||||||
};
|
};
|
||||||
@ -22,14 +22,34 @@ var users = function(dbot) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var updateChannels = function(event, oldUser, newUser) {
|
||||||
|
var channelUsers = getServerUsers(event.server).channelUsers;
|
||||||
|
channelUsers.each(function(channel) {
|
||||||
|
if(channel.include(oldUser)) {
|
||||||
|
channel.splice(channel.indexOf(oldUser), 1);
|
||||||
|
channel.push(newUser);
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
|
}
|
||||||
|
|
||||||
dbot.instance.addListener('366', 'users', function(event) {
|
dbot.instance.addListener('366', 'users', function(event) {
|
||||||
var knownUsers = getServerUsers(event.server);
|
var knownUsers = getServerUsers(event.server);
|
||||||
for(var nick in event.channel.nicks) {
|
if(!knownUsers.channelUsers.hasOwnProperty(event.channel.name)) {
|
||||||
if(!knownUsers.users.include(nick) && !knownUsers.aliases.hasOwnProperty(nick) &&
|
knownUsers.channelUsers[event.channel.name] = [];
|
||||||
event.channel.nicks.hasOwnProperty(nick)) {
|
}
|
||||||
|
var channelUsers = knownUsers.channelUsers[event.channel.name];
|
||||||
|
|
||||||
|
event.channel.nicks.each(function(nick) {
|
||||||
|
nick = nick.name;
|
||||||
|
if(api.isKnownUser(event.server, nick)) {
|
||||||
|
nick = api.resolveUser(nick);
|
||||||
|
} else {
|
||||||
knownUsers.users.push(nick);
|
knownUsers.users.push(nick);
|
||||||
}
|
}
|
||||||
}
|
if(!channelUsers.include(nick)) {
|
||||||
|
channelUsers.push(nick);
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
});
|
});
|
||||||
|
|
||||||
var pages = {
|
var pages = {
|
||||||
@ -101,6 +121,11 @@ var users = function(dbot) {
|
|||||||
|
|
||||||
if(useLowercase) user = user.toLowerCase();
|
if(useLowercase) user = user.toLowerCase();
|
||||||
return user;
|
return user;
|
||||||
|
},
|
||||||
|
|
||||||
|
'isKnownUser': function(server, nick) {
|
||||||
|
var knownUsers = getServerUsers(server);
|
||||||
|
return (knownUsers.users.include(nick) || knownUsers.aliases.hasOwnProperty(nick));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -135,6 +160,9 @@ var users = function(dbot) {
|
|||||||
knownUsers.users.splice(usersIndex, 1);
|
knownUsers.users.splice(usersIndex, 1);
|
||||||
knownUsers.users.push(newParent);
|
knownUsers.users.push(newParent);
|
||||||
|
|
||||||
|
// Replace channels entries with new primary user
|
||||||
|
updateChannels(event, newAlias, newParent);
|
||||||
|
|
||||||
// Remove alias for new parent & add alias for new alias
|
// Remove alias for new parent & add alias for new alias
|
||||||
delete knownUsers.aliases[newParent];
|
delete knownUsers.aliases[newParent];
|
||||||
knownUsers.aliases[newAlias] = newParent;
|
knownUsers.aliases[newAlias] = newParent;
|
||||||
@ -162,6 +190,7 @@ var users = function(dbot) {
|
|||||||
knownUsers.users.splice(knownUsers.users.indexOf(secondaryUser), 1);
|
knownUsers.users.splice(knownUsers.users.indexOf(secondaryUser), 1);
|
||||||
knownUsers.aliases[secondaryUser] = primaryUser;
|
knownUsers.aliases[secondaryUser] = primaryUser;
|
||||||
updateAliases(event, secondaryUser, primaryUser);
|
updateAliases(event, secondaryUser, primaryUser);
|
||||||
|
updateChannels(event, secondaryUser, primaryUser);
|
||||||
|
|
||||||
event.reply(dbot.t('merged_users', {
|
event.reply(dbot.t('merged_users', {
|
||||||
'old_user': secondaryUser,
|
'old_user': secondaryUser,
|
||||||
@ -185,9 +214,21 @@ var users = function(dbot) {
|
|||||||
|
|
||||||
'listener': function(event) {
|
'listener': function(event) {
|
||||||
var knownUsers = getServerUsers(event.server);
|
var knownUsers = getServerUsers(event.server);
|
||||||
|
var nick = event.user;
|
||||||
|
|
||||||
if(event.action == 'JOIN') {
|
if(event.action == 'JOIN') {
|
||||||
if(!knownUsers.users.include(event.user)) {
|
if(!knownUsers.channelUsers.hasOwnProperty(event.channel.name)) {
|
||||||
knownUsers.users.push(event.user);
|
knownUsers.channelUsers[event.channel.name] = [];
|
||||||
|
}
|
||||||
|
var channelUsers = knownUsers.channelUsers[event.channel.name];
|
||||||
|
|
||||||
|
if(api.isKnownUser(event.server, nick)) {
|
||||||
|
nick = api.resolveUser(nick);
|
||||||
|
} else {
|
||||||
|
knownUsers.users.push(nick);
|
||||||
|
}
|
||||||
|
if(!channelUsers.include(nick)) {
|
||||||
|
channelUsers.push(nick);
|
||||||
}
|
}
|
||||||
} else if(event.action == 'NICK') {
|
} else if(event.action == 'NICK') {
|
||||||
var newNick = event.params.substr(1);
|
var newNick = event.params.substr(1);
|
||||||
|
Loading…
Reference in New Issue
Block a user