mirror of
https://github.com/reality/dbot.git
synced 2025-01-25 19:44:22 +01:00
users module almost fully operational with databank (few kinks in moderation commands still) [#272]
This commit is contained in:
parent
ef9f5f2646
commit
3814df98f6
@ -14,7 +14,8 @@ var api = function(dbot) {
|
|||||||
// Return a user record given a primary nick or an alias
|
// Return a user record given a primary nick or an alias
|
||||||
'resolveUser': function(server, nick, callback) {
|
'resolveUser': function(server, nick, callback) {
|
||||||
var user = false;
|
var user = false;
|
||||||
this.db.search('user', { 'server': server }, function(result) {
|
this.db.search('users', { 'server': server }, function(result) {
|
||||||
|
console.log(result.primaryNick);
|
||||||
if(result.primaryNick == nick || _.include(result.aliases, nick)) {
|
if(result.primaryNick == nick || _.include(result.aliases, nick)) {
|
||||||
user = result;
|
user = result;
|
||||||
}
|
}
|
||||||
@ -25,11 +26,11 @@ var api = function(dbot) {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
'getChannel': function(server, channel, callback) {
|
'getChannel': function(server, channelName, callback) {
|
||||||
var channel = false;
|
var channel = false;
|
||||||
this.db.search('channel_users', {
|
this.db.search('channel_users', {
|
||||||
'server': server,
|
'server': server,
|
||||||
'name': channel
|
'name': channelName
|
||||||
}, function(result) {
|
}, function(result) {
|
||||||
channel = result;
|
channel = result;
|
||||||
}, function(err) {
|
}, function(err) {
|
||||||
|
@ -3,98 +3,95 @@ var _ = require('underscore')._;
|
|||||||
var commands = function(dbot) {
|
var commands = function(dbot) {
|
||||||
var commands = {
|
var commands = {
|
||||||
'~alias': function(event) {
|
'~alias': function(event) {
|
||||||
var knownUsers = this.getServerUsers(event.server),
|
var nick = event.params[1].trim();
|
||||||
alias = event.params[1].trim();
|
this.api.resolveUser(event.server, nick, function(user) {
|
||||||
|
if(user) {
|
||||||
|
if(nick == user.primaryNick) {
|
||||||
|
var aliases = _.first(user.aliases, 10);
|
||||||
|
var including = 'including: ' + aliases.join(', ') + '.';
|
||||||
|
|
||||||
if(_.include(knownUsers.users, alias)) {
|
if(user.aliases.length != 0) {
|
||||||
var aliases = this.api.getAliases(event.server, alias);
|
event.reply(dbot.t('primary', {
|
||||||
var aliasCount = aliases.length;
|
'user': nick,
|
||||||
|
'count': user.aliases.length,
|
||||||
if(aliasCount != 0) {
|
}) + including);
|
||||||
var aliases = _.first(aliases, 10);
|
} else {
|
||||||
var including = 'including: ' + aliases.join(', ') + '.';
|
event.reply(dbot.t('primary', {
|
||||||
|
'user': nick,
|
||||||
event.reply(dbot.t('primary', {
|
'count': user.aliases.length
|
||||||
'user': alias,
|
}).slice(0, -2) + ".");
|
||||||
'count': aliasCount
|
}
|
||||||
}) + including);
|
} else {
|
||||||
|
event.reply(dbot.t('alias', {
|
||||||
|
'alias': nick,
|
||||||
|
'user': user.primaryNick
|
||||||
|
}));
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
event.reply(dbot.t('primary', {
|
event.reply(dbot.t('unknown_alias', { 'alias': nick }));
|
||||||
'user': alias,
|
|
||||||
'count': aliasCount
|
|
||||||
}).slice(0, -2) + ".");
|
|
||||||
}
|
}
|
||||||
} else if(_.has(knownUsers.aliases, alias)) {
|
});
|
||||||
event.reply(dbot.t('alias', {
|
|
||||||
'alias': alias,
|
|
||||||
'user': knownUsers.aliases[alias]
|
|
||||||
}));
|
|
||||||
} else {
|
|
||||||
event.reply(dbot.t('unknown_alias', { 'alias': alias }));
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
'~setaliasparent': function(event) {
|
'~setaliasparent': function(event) {
|
||||||
var knownUsers = this.getServerUsers(event.server);
|
var newPrimary = event.params[1].trim();
|
||||||
var newParent = event.params[1];
|
this.api.resolveUser(event.server, newPrimary, function(user) {
|
||||||
|
if(user) {
|
||||||
|
var newAlias = user.primaryNick;
|
||||||
|
user.primaryNick = newPrimary;
|
||||||
|
user.aliases = _.without(user.aliases, newPrimary).push(newAlias);
|
||||||
|
this.internalAPI.updateChannelPrimaryUser(event.server, newAlias, newPrimary);
|
||||||
|
|
||||||
if(_.has(knownUsers.aliases, newParent)) {
|
this.db.save('users', user.id, user, function(err) {
|
||||||
var newAlias = knownUsers.aliases[newParent];
|
if(!err) {
|
||||||
|
dbot.api.event.emit('~setaliasparent', {
|
||||||
// Replace user entry
|
'server': event.server,
|
||||||
knownUsers.users = _.without(knownUsers.users, newAlias);
|
'alias': newAlias
|
||||||
knownUsers.users.push(newParent);
|
});
|
||||||
|
}
|
||||||
// Replace channels entries with new primary user
|
});
|
||||||
this.updateChannels(event, newAlias, newParent);
|
} else {
|
||||||
|
event.reply(dbot.t('unknown_alias', { 'alias': newParent }));
|
||||||
// Remove alias for new parent & add alias for new alias
|
}
|
||||||
delete knownUsers.aliases[newParent];
|
}.bind(this));
|
||||||
knownUsers.aliases[newAlias] = newParent;
|
|
||||||
|
|
||||||
// Update aliases to point to new primary user
|
|
||||||
this.updateAliases(event, newAlias, newParent);
|
|
||||||
|
|
||||||
event.reply(dbot.t('aliasparentset', {
|
|
||||||
'newParent': newParent,
|
|
||||||
'newAlias': newAlias
|
|
||||||
}));
|
|
||||||
|
|
||||||
return {
|
|
||||||
'server': event.server,
|
|
||||||
'alias': newAlias
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
event.reply(dbot.t('unknown_alias', { 'alias': newParent }));
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
'~mergeusers': function(event) {
|
'~mergeusers': function(event) {
|
||||||
var knownUsers = this.getServerUsers(event.server);
|
|
||||||
var primaryUser = event.params[1];
|
var primaryUser = event.params[1];
|
||||||
var secondaryUser = event.params[2];
|
var secondaryUser = event.params[2];
|
||||||
|
|
||||||
if(_.include(knownUsers.users, primaryUser) && _.include(knownUsers.users, secondaryUser)) {
|
this.api.resolveUser(event.server, primaryUser, function(user) {
|
||||||
knownUsers.users = _.without(knownUsers.users, secondaryUser);
|
if(user) {
|
||||||
knownUsers.aliases[secondaryUser] = primaryUser;
|
this.api.resolveUser(event.server, secondaryUser, function(secondaryUser) {
|
||||||
this.updateAliases(event, secondaryUser, primaryUser);
|
if(secondaryUser) {
|
||||||
this.updateChannels(event, secondaryUser, primaryUser);
|
user.aliases.push(secondaryUser.primaryNick);
|
||||||
|
user.aliases.concat(secondaryUser.aliases);
|
||||||
event.reply(dbot.t('merged_users', {
|
this.db.del('users', secondaryUser.id, function(err) {
|
||||||
'old_user': secondaryUser,
|
if(!err) {
|
||||||
'new_user': primaryUser
|
this.db.save('users', user.id, user, function(err) {
|
||||||
}));
|
if(!err) {
|
||||||
|
this.updateChannels(event, secondaryUser, primaryUser);
|
||||||
return {
|
event.reply(dbot.t('merged_users', {
|
||||||
'server': event.server,
|
'old_user': secondaryUser,
|
||||||
'secondary': secondaryUser
|
'new_user': primaryUser
|
||||||
};
|
}));
|
||||||
} else {
|
dbot.api.event.emit('~mergeusers', {
|
||||||
event.reply(dbot.t('unprimary_error'));
|
'server': event.server,
|
||||||
}
|
'secondary': secondaryUser
|
||||||
return false;
|
});
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
event.reply(dbot.t('unprimary_error'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
event.reply(dbot.t('unprimary_error'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
commands['~alias'].regex = [/^~alias ([\d\w[\]{}^|\\`_-]+?)/, 2];
|
commands['~alias'].regex = [/^~alias ([\d\w[\]{}^|\\`_-]+?)/, 2];
|
||||||
|
@ -2,28 +2,12 @@
|
|||||||
* Name: Users
|
* Name: Users
|
||||||
* Description: Track known users
|
* Description: Track known users
|
||||||
*/
|
*/
|
||||||
var _ = require('underscore')._;
|
var _ = require('underscore')._,
|
||||||
|
uuid = require('node-uuid');
|
||||||
|
|
||||||
var users = function(dbot) {
|
var users = function(dbot) {
|
||||||
this.knownUsers = dbot.db.knownUsers;
|
|
||||||
|
|
||||||
this.updateAliases = function(event, oldUser, newUser) {
|
|
||||||
var knownUsers = this.getServerUsers(event.server);
|
|
||||||
_.each(knownUsers.aliases, function(user, alias) {
|
|
||||||
if(user == oldUser) {
|
|
||||||
knownUsers.aliases[alias] = newUser;
|
|
||||||
}
|
|
||||||
}, this);
|
|
||||||
};
|
|
||||||
|
|
||||||
this.updateChannels = function(event, oldUser, newUser) {
|
|
||||||
var channelUsers = this.getServerUsers(event.server).channelUsers;
|
|
||||||
channelUsers = _.each(channelUsers, function(channel, channelName) {
|
|
||||||
channelUsers[channelName] = _.without(channel, oldUser);
|
|
||||||
channelUsers[channelName].push(newUser);
|
|
||||||
}, this);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
/*** Internal API ***/
|
||||||
this.internalAPI = {
|
this.internalAPI = {
|
||||||
'createUser': function(server, nick, channel, callback) {
|
'createUser': function(server, nick, channel, callback) {
|
||||||
var id = uuid.v4();
|
var id = uuid.v4();
|
||||||
@ -36,14 +20,17 @@ var users = function(dbot) {
|
|||||||
'aliases': []
|
'aliases': []
|
||||||
}, function(err, result) {
|
}, function(err, result) {
|
||||||
if(!err) {
|
if(!err) {
|
||||||
dbot.api.event.emit('new_user', [ user ]);
|
dbot.api.event.emit('new_user', [ result ]);
|
||||||
callback(result);
|
callback(result);
|
||||||
|
dbot.say('aberwiki', '#realitest', result.server);
|
||||||
|
dbot.say('aberwiki', '#realitest', result.primaryNick);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
},
|
}.bind(this),
|
||||||
|
|
||||||
'addChannelUser': function(user, channelName) {
|
'addChannelUser': function(user, channelName) {
|
||||||
user.channels.push(channelName);
|
user.channels.push(channelName);
|
||||||
|
dbot.say('aberwiki', '#realitest', user.id);
|
||||||
this.db.save('users', user.id, user, function(err) {
|
this.db.save('users', user.id, user, function(err) {
|
||||||
if(!err) {
|
if(!err) {
|
||||||
this.api.getChannel(user.server, channelName, function(channel) {
|
this.api.getChannel(user.server, channelName, function(channel) {
|
||||||
@ -56,46 +43,68 @@ var users = function(dbot) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}.bind(this),
|
||||||
|
|
||||||
|
'updateChannelPrimaryUser': function(server, oldUser, newUser) {
|
||||||
|
this.db.search('channel_users', { 'server': server }, function(channel) {
|
||||||
|
channel.users = _.without(channel.users, oldUser);
|
||||||
|
if(!_.include(channel.users, newUser)) channel.users.push(newUser);
|
||||||
|
this.db.save('channel_users', channel.id, channel, function(err) {
|
||||||
|
if(err) {
|
||||||
|
// QQ
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}.bind(this), function(err) {
|
||||||
|
if(err) {
|
||||||
|
// QQ
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}.bind(this)
|
||||||
};
|
};
|
||||||
|
|
||||||
this.listener = function(event) {
|
this.listener = function(event) {
|
||||||
if(event.action == 'JOIN' && nick != dbot.config.name) {
|
if(event.action == 'JOIN' && event.user != dbot.config.name) {
|
||||||
this.api.resolveUser(event.server, event.user, function(user) {
|
this.api.resolveUser(event.server, event.user, function(user) {
|
||||||
if(!user) { // User does not yet exist
|
if(!user) { // User does not yet exist
|
||||||
this.internalAPI.createUser(event.server, event.user, event.channel, function(result) {
|
this.internalAPI.createUser(event.server, event.user, event.channel, function(result) {
|
||||||
user = result;
|
user = result;
|
||||||
});
|
if(!_.include(user.channels, event.channel)) { // User not yet channel user
|
||||||
}
|
this.internalAPI.addChannelUser(user, event.channel.name);
|
||||||
|
|
||||||
if(!_.include(user.channels, event.channel)) { // User not yet channel user
|
|
||||||
this.internalAPI.addChannelUser(user, event.channel);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if(event.action == 'NICK') {
|
|
||||||
if(!this.api.isKnownUser(event.newNick)) {
|
|
||||||
this.api.resolveUser(event.server, event.user, function(user) {
|
|
||||||
user.aliases.push(event.newNick);
|
|
||||||
this.db.save('users', user.id, function(err) {
|
|
||||||
if(!err) {
|
|
||||||
dbot.api.event.emit('new_user_alias', [ user, event.newNick ]);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
} else {
|
||||||
}
|
if(!_.include(user.channels, event.channel)) { // User not yet channel user
|
||||||
|
this.internalAPI.addChannelUser(user, event.channel.name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
|
} else if(event.action == 'NICK') {
|
||||||
|
this.api.isKnownUser(event.server, event.newNick, function(isKnown) {
|
||||||
|
if(!isKnown) {
|
||||||
|
this.api.resolveUser(event.server, event.user, function(user) {
|
||||||
|
dbot.say('aberwiki', '#realitest', event.newNick);
|
||||||
|
user.aliases.push(event.newNick);
|
||||||
|
this.db.save('users', user.id, user, function(err) {
|
||||||
|
if(!err) {
|
||||||
|
dbot.api.event.emit('new_user_alias', [ user, event.newNick ]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}.bind(this));
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
}
|
}
|
||||||
}.bind(this);
|
}.bind(this);
|
||||||
this.on = ['JOIN', 'NICK'];
|
this.on = ['JOIN', 'NICK'];
|
||||||
|
|
||||||
this.onLoad = function() {
|
this.onLoad = function() {
|
||||||
dbot.instance.addListener('366', 'users', function(event) {
|
dbot.instance.addListener('366', 'users', function(event) {
|
||||||
this.api.getChannel(event.server, event.channel, function(channel) {
|
this.api.getChannel(event.server, event.channel.name, function(channel) {
|
||||||
if(!channel) { // Channel does not yet exist
|
if(!channel) { // Channel does not yet exist
|
||||||
var id = uuid.v4();
|
var id = uuid.v4();
|
||||||
this.db.create('channel_users', id, {
|
this.db.create('channel_users', id, {
|
||||||
'uuid': id,
|
'uuid': id,
|
||||||
'server': event.server,
|
'server': event.server,
|
||||||
'name': event.channel,
|
'name': event.channel.name,
|
||||||
'users': []
|
'users': []
|
||||||
}, function(err, result) {
|
}, function(err, result) {
|
||||||
if(!err) {
|
if(!err) {
|
||||||
@ -106,24 +115,28 @@ var users = function(dbot) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_.each(event.channel.nicks, function(nick) {
|
_.each(event.channel.nicks, function(nick) {
|
||||||
|
var nick = nick.name;
|
||||||
this.api.resolveUser(event.server, nick, function(user) {
|
this.api.resolveUser(event.server, nick, function(user) {
|
||||||
if(!user) {
|
if(!user) {
|
||||||
this.internalAPI.createUser(event.server, nick, event.channel, function(result) {
|
this.internalAPI.createUser(event.server, nick, event.channel, function(result) {
|
||||||
user = result;
|
user = result;
|
||||||
|
if(!_.include(user.channels, event.channel)) {
|
||||||
|
this.internalAPI.addChannelUser(user, event.channel.name);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
if(!_.include(user.channels, event.channel)) {
|
||||||
|
this.internalAPI.addChannelUser(user, event.channel.name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
}.bind(this));
|
||||||
if(!_.include(user.channels, event.channel)) {
|
|
||||||
this.internalAPI.addChannelUser(user, event.channel);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}, this);
|
}, this);
|
||||||
});
|
}.bind(this));
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
var connections = dbot.instance.connections;
|
var connections = dbot.instance.connections;
|
||||||
_.each(connections, function(connection) {
|
_.each(connections, function(connection) {
|
||||||
connection.updateNickLists();
|
connection.updateNickLists();
|
||||||
});
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user