muh
This commit is contained in:
parent
aefc42fe71
commit
4fc92320b3
@ -1,3 +1,7 @@
|
|||||||
|
var allowedModes = [
|
||||||
|
'q','a','o','h','v'
|
||||||
|
];
|
||||||
|
|
||||||
module.exports = (bot, trigger, lib) => {
|
module.exports = (bot, trigger, lib) => {
|
||||||
trigger.add({
|
trigger.add({
|
||||||
name: 'umode',
|
name: 'umode',
|
||||||
@ -5,31 +9,6 @@ module.exports = (bot, trigger, lib) => {
|
|||||||
level: 100,
|
level: 100,
|
||||||
active: 1,
|
active: 1,
|
||||||
func: (e) => {
|
func: (e) => {
|
||||||
var processModes = (modes) => {
|
|
||||||
var delta, modeList = [];
|
|
||||||
if(modes.split('').some((token) => {
|
|
||||||
if(token === '-') {delta = false; return;}
|
|
||||||
if(token === '+') {delta = true; return;}
|
|
||||||
if(token === ' ') return;
|
|
||||||
if(typeof delta === "undefined") return true;
|
|
||||||
modeList.push({
|
|
||||||
delta: delta,
|
|
||||||
mode: token
|
|
||||||
});
|
|
||||||
})) return false;
|
|
||||||
return [...new Set(modeList)];
|
|
||||||
};
|
|
||||||
var checkModes = (modes, allowedModes) => {
|
|
||||||
if([...new Set(modes.map(a => a.mode))].some((mode) => {
|
|
||||||
if(allowedModes.some((allowedMode) => {
|
|
||||||
if(allowedMode != mode) return true;
|
|
||||||
})) return true;
|
|
||||||
})) return false;
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
var allowedModes = [
|
|
||||||
'q','a','o','h','v'
|
|
||||||
];
|
|
||||||
var tmp = e.message.trim().split(' ');
|
var tmp = e.message.trim().split(' ');
|
||||||
tmp.shift();
|
tmp.shift();
|
||||||
var user = tmp[tmp.length - 1];
|
var user = tmp[tmp.length - 1];
|
||||||
@ -39,44 +18,50 @@ module.exports = (bot, trigger, lib) => {
|
|||||||
tmp.pop();
|
tmp.pop();
|
||||||
e.reply("input: "+JSON.stringify(tmp));
|
e.reply("input: "+JSON.stringify(tmp));
|
||||||
var modes;
|
var modes;
|
||||||
if(modes = processModes(tmp.join(' '))) {
|
|
||||||
if(checkModes(modes, allowedModes)) {
|
|
||||||
//---apply modes---
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
e.reply('Error! Allowed modes are: ' + allowedModes.join(',');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
e.reply('Syntax Error!');
|
|
||||||
}
|
|
||||||
e.reply("output: "+JSON.stringify(modes));
|
|
||||||
e.reply("user: "+user);
|
|
||||||
|
|
||||||
return;
|
|
||||||
var user = modes[modes.length - 1];
|
|
||||||
if(user.toLowerCase() != bot.me.nick.toLowerCase()) {
|
if(user.toLowerCase() != bot.me.nick.toLowerCase()) {
|
||||||
if(user.match(/(\+|-)/))
|
if(user in e.channel.names) {
|
||||||
user = e.user.getNick();
|
if(modes = processModes(tmp.join(' '))) {
|
||||||
modes.shift();
|
if(checkModes(modes, allowedModes))
|
||||||
var tmp = [];
|
modes.forEach((entry,i,a) => {
|
||||||
modes.forEach((entry,i,a) => {
|
bot.mode(e.channel, (entry.delta?'+':'-')+entry.mode+' '+user, e.network);
|
||||||
if(entry.match(/((\+|-)[a-z]{1}$)/))
|
});
|
||||||
tmp.push(entry);
|
else
|
||||||
});
|
e.reply('Error! Allowed modes are: ' + allowedModes.join(','));
|
||||||
|
}
|
||||||
if(tmp.length > 0) {
|
else
|
||||||
e.reply('modes: ' + JSON.stringify(tmp) + ' to user: '+user);
|
e.reply('Syntax Error!');
|
||||||
tmp.forEach((entry,i,a) => {
|
|
||||||
bot.mode(e.channel, entry+' '+user, e.network);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
e.reply('no modes given');
|
e.reply('user not found!');
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
e.reply('f0ck you.');
|
e.reply('f0ck you hard');
|
||||||
|
e.reply("output: "+JSON.stringify(modes));
|
||||||
},
|
},
|
||||||
desc: 'change Usermodes'
|
desc: 'change Usermodes'
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var processModes = (modes) => {
|
||||||
|
var delta, modeList = [];
|
||||||
|
if(modes.split('').some((token) => {
|
||||||
|
if(token === '-') {delta = false; return;}
|
||||||
|
if(token === '+') {delta = true; return;}
|
||||||
|
if(token === ' ') return;
|
||||||
|
if(typeof delta === "undefined") return true;
|
||||||
|
modeList.push({
|
||||||
|
delta: delta,
|
||||||
|
mode: token
|
||||||
|
});
|
||||||
|
})) return false;
|
||||||
|
return [...new Set(modeList)];
|
||||||
|
};
|
||||||
|
|
||||||
|
var checkModes = (modes, allowedModes) => {
|
||||||
|
if([...new Set(modes.map(a => a.mode))].some((mode) => {
|
||||||
|
for(var i = 0; i <= allowedModes.length; i++)
|
||||||
|
if(allowedModes[i] == mode) return false;
|
||||||
|
return true;
|
||||||
|
})) return false;
|
||||||
|
return true;
|
||||||
};
|
};
|
Loading…
x
Reference in New Issue
Block a user