Prevent setting values to array settings and prevent adding to non-array

settings
This commit is contained in:
jesopo 2018-12-05 12:13:29 +00:00
parent 08a74d8b4d
commit 764e1e3245
2 changed files with 12 additions and 5 deletions

View file

@ -28,7 +28,7 @@ COMMENT_ACTIONS = {
@utils.export("channelset", {"setting": "github-hook",
"help": ("Disable/Enable showing BitBot's github commits in the "
"current channel")})
"current channel"), "array": True})
@utils.export("channelset", {"setting": "github-hide-prefix",
"help": "Hide/show command-like prefix on Github hook outputs",
"validate": utils.bool_or_none})

View file

@ -7,15 +7,22 @@ CHANNELSETADD_HELP = ("Add to a specified channel setting for the "
class Module(ModuleManager.BaseModule):
def _set(self, category, event, target, array):
settings = self.exports.get_all(category)
settings_dict = dict([(setting["setting"], setting
) for setting in settings])
settings_dict = {setting["setting"]: setting for setting in settings}
if len(event["args_split"]) > 1:
setting = event["args_split"][0].lower()
if setting in settings_dict:
setting_options = settings_dict[setting]
if not setting_options.get("array", False) == array:
if array:
raise utils.EventError(
"Can't add to a non-array setting")
else:
raise utils.EventError(
"You can only 'add' to an array setting")
value = " ".join(event["args_split"][1:])
value = settings_dict[setting].get("validate",
lambda x: x)(value)
value = setting_options.get("validate", lambda x: x)(value)
if not value == None:
if array: