mirror of https://github.com/calzoneman/sync.git
Allow limiting # items per user
This commit is contained in:
parent
084b1cf16f
commit
e13e695077
|
@ -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);
|
||||||
};
|
};
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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", {
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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+"");
|
||||||
|
|
Loading…
Reference in New Issue