Allow limiting # items per user

This commit is contained in:
calzoneman 2014-10-06 11:32:25 -05:00
parent 084b1cf16f
commit e13e695077
5 changed files with 36 additions and 3 deletions

View File

@ -24,7 +24,8 @@ function OptionsModule(channel) {
password: false, // Channel password (false -> no password required for entry) password: false, // Channel password (false -> no password required for entry)
allow_dupes: false, // Allow duplicate videos on the playlist allow_dupes: false, // Allow duplicate videos on the playlist
torbanned: false, // Block connections from Tor exit nodes torbanned: false, // Block connections from Tor exit nodes
allow_ascii_control: false // Allow ASCII control characters (\x00-\x1f) allow_ascii_control: false,// Allow ASCII control characters (\x00-\x1f)
playlist_max_per_user: 0 // Maximum number of playlist items per user
}; };
} }
@ -254,6 +255,13 @@ OptionsModule.prototype.handleSetOptions = function (user, data) {
this.opts.allow_ascii_control = Boolean(data.allow_ascii_control); this.opts.allow_ascii_control = Boolean(data.allow_ascii_control);
} }
if ("playlist_max_per_user" in data && user.account.effectiveRank >= 3) {
var max = parseInt(data.playlist_max_per_user);
if (!isNaN(max) && max >= 0) {
this.opts.playlist_max_per_user = max;
}
}
this.channel.logger.log("[mod] " + user.getName() + " updated channel options"); this.channel.logger.log("[mod] " + user.getName() + " updated channel options");
this.sendOpts(this.channel.users); this.sendOpts(this.channel.users);
}; };

View File

@ -40,7 +40,8 @@ const DEFAULT_PERMISSIONS = {
leaderctl: 2, // Give/take leader leaderctl: 2, // Give/take leader
drink: 1.5, // Use the /d command drink: 1.5, // Use the /d command
chat: 0, // Send chat messages chat: 0, // Send chat messages
chatclear: 2 // Use the /clear command chatclear: 2, // Use the /clear command
exceedmaxitems: 2 // Exceed maximum items per user limit
}; };
function PermissionsModule(channel) { function PermissionsModule(channel) {
@ -342,6 +343,10 @@ PermissionsModule.prototype.canUncache = function (actor) {
return actor.effectiveRank >= 2; return actor.effectiveRank >= 2;
}; };
PermissionsModule.prototype.canExceedMaxItemsPerUser = function (actor) {
return this.hasPermission(actor, "exceedmaxitems");
};
PermissionsModule.prototype.loadUnregistered = function () { PermissionsModule.prototype.loadUnregistered = function () {
var perms = { var perms = {
seeplaylist: -1, seeplaylist: -1,
@ -373,7 +378,8 @@ PermissionsModule.prototype.loadUnregistered = function () {
leaderctl: 0, // Give/take leader leaderctl: 0, // Give/take leader
drink: 0, // Use the /d command drink: 0, // Use the /d command
chat: 0, // Send chat messages chat: 0, // Send chat messages
chatclear: 2 // Use the /clear command chatclear: 2, // Use the /clear command
exceedmaxitems: 2 // Exceed max items per user
}; };
for (var key in perms) { for (var key in perms) {

View File

@ -868,6 +868,19 @@ PlaylistModule.prototype._addItem = function (media, data, user, cb) {
return qfail("This item is already on the playlist"); return qfail("This item is already on the playlist");
} }
var usersItems = this.items.findAll(function (item) {
return item.queueby.toLowerCase() === user.getLowerName();
});
if (this.channel.modules.options &&
this.channel.modules.options.get("playlist_max_per_user") &&
usersItems.length >= this.channel.modules.options.get("playlist_max_per_user")) {
if (!this.channel.modules.permissions.canExceedMaxItemsPerUser(user)) {
return qfail("Channel limit exceeded: maximum number of videos per user");
}
}
/* Warn about blocked countries */ /* Warn about blocked countries */
if (media.meta.restricted) { if (media.meta.restricted) {
user.socket.emit("queueWarn", { user.socket.emit("queueWarn", {

View File

@ -77,6 +77,10 @@ mixin adminoptions
mixin rcheckbox-auto("cs-show_public", "List channel publicly") mixin rcheckbox-auto("cs-show_public", "List channel publicly")
mixin rcheckbox-auto("cs-torbanned", "Block connections from Tor") mixin rcheckbox-auto("cs-torbanned", "Block connections from Tor")
mixin rcheckbox-auto("cs-allow_ascii_control", "Allow ASCII control characters (e.g. newlines)") mixin rcheckbox-auto("cs-allow_ascii_control", "Allow ASCII control characters (e.g. newlines)")
mixin textbox-auto("cs-playlist_max_per_user", "Maximum # of videos per user")
.form-group
.col-sm-8.col-sm-offset-4
span.text-info Set to 0 for no limit
.form-group .form-group
.col-sm-8.col-sm-offset-4 .col-sm-8.col-sm-offset-4
span.text-info Changes are automatically saved. span.text-info Changes are automatically saved.

View File

@ -866,6 +866,7 @@ function handleModPermissions() {
$("#cs-allow_dupes").prop("checked", CHANNEL.opts.allow_dupes); $("#cs-allow_dupes").prop("checked", CHANNEL.opts.allow_dupes);
$("#cs-torbanned").prop("checked", CHANNEL.opts.torbanned); $("#cs-torbanned").prop("checked", CHANNEL.opts.torbanned);
$("#cs-allow_ascii_control").prop("checked", CHANNEL.opts.allow_ascii_control); $("#cs-allow_ascii_control").prop("checked", CHANNEL.opts.allow_ascii_control);
$("#cs-playlist_max_per_user").val(CHANNEL.opts.playlist_max_per_user || 0);
(function() { (function() {
if(typeof CHANNEL.opts.maxlength != "number") { if(typeof CHANNEL.opts.maxlength != "number") {
$("#cs-maxlength").val(""); $("#cs-maxlength").val("");
@ -1755,6 +1756,7 @@ function genPermissionsEditor() {
makeOption("Embed custom media", "playlistaddcustom", standard, CHANNEL.perms.playlistaddcustom + ""); makeOption("Embed custom media", "playlistaddcustom", standard, CHANNEL.perms.playlistaddcustom + "");
makeOption("Add raw video file", "playlistaddrawfile", standard, CHANNEL.perms.playlistaddrawfile + ""); makeOption("Add raw video file", "playlistaddrawfile", standard, CHANNEL.perms.playlistaddrawfile + "");
makeOption("Exceed maximum media length", "exceedmaxlength", standard, CHANNEL.perms.exceedmaxlength+""); makeOption("Exceed maximum media length", "exceedmaxlength", standard, CHANNEL.perms.exceedmaxlength+"");
makeOption("Exceed maximum number of videos per user", "exceedmaxitems", standard, CHANNEL.perms.exceedmaxitems+"");
makeOption("Add nontemporary media", "addnontemp", standard, CHANNEL.perms.addnontemp+""); makeOption("Add nontemporary media", "addnontemp", standard, CHANNEL.perms.addnontemp+"");
makeOption("Temp/untemp playlist item", "settemp", standard, CHANNEL.perms.settemp+""); makeOption("Temp/untemp playlist item", "settemp", standard, CHANNEL.perms.settemp+"");
makeOption("Lock/unlock playlist", "playlistlock", modleader, CHANNEL.perms.playlistlock+""); makeOption("Lock/unlock playlist", "playlistlock", modleader, CHANNEL.perms.playlistlock+"");