summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDico200 <dico.karssiens@gmail.com>2016-05-29 23:49:45 +0200
committerDico200 <dico.karssiens@gmail.com>2016-05-29 23:49:45 +0200
commit361da9e049ec9b575b2b78eb7b663e6efeff6950 (patch)
tree52b216d78908a0b013403260758417651b018b4a
parent33d8fd2f08df21052cb2c9a6b30b49baa61305cd (diff)
Chatalias: Fixed all the things (permission AMOUNT, permission LENGTH, and more), incremented version number
-rw-r--r--chatalias.py164
1 files changed, 89 insertions, 75 deletions
diff --git a/chatalias.py b/chatalias.py
index 449a68f..0e2b297 100644
--- a/chatalias.py
+++ b/chatalias.py
@@ -1,14 +1,4 @@
-############################################
-# Alias v2.0 by Pepich #
-# Changes to previous version from curs3d: #
-# Dynamic alias limit from permissions #
-# AC/CG/MSG support #
-# Color support #
-# Bugfixes #
-# #
-# TODO: #
-# Add command support... #
-############################################
+# TODO: Add cg/ac/msg support
import os
import mysqlhack
@@ -20,15 +10,14 @@ from secrets import *
# Version number and requirements
-alias_version = "2.0.0"
+alias_version = "2.1.0"
helpers_versions = ["1.1.0", "2.0.0"]
enabled = False
-error = colorify("&cUnspecified error")
+error_msg = colorify("&cUnspecified error")
commands_per_page = 5
global_aliases = {"./":"/"}
data = {}
-# DON'T SET THIS TO TRUE! MySQL requestst are NOT ASYNC yet! (And for some reason it doesn't want to store any data ._.)
-use_mysql = False
+use_mysql = True
# Permissions:
@@ -60,8 +49,8 @@ def safe_open_json(uuid):
os.makedirs("plugins/redstoner-utils.py.dir/files/aliases")
value = open_json_file("aliases/" + uuid)
if value is None:
- value = global_aliases
- save_json_file("aliases/" + uuid, value)
+ value = dict(global_aliases)
+ save_json_file("aliases/" + uuid, value)
return value
@@ -69,6 +58,9 @@ def safe_open_json(uuid):
usage="/<command> <add, remove, list, help> [...]",
desc="Allows aliasing of words")
def on_alias_command(sender, cmd, label, args):
+ if not is_player(sender):
+ msg(sender, "&cThe console cannot use aliases!")
+ return True
try:
args = array_to_list(args)
if not enabled:
@@ -130,24 +122,23 @@ def on_join(event):
@hook.event("player.AsyncPlayerChatEvent", "high")
def on_player_chat(event):
- try:
- if enabled:
- if event.isCancelled():
- return
- if not hasPerm(event.getPlayer(), permission_USE):
+ if enabled:
+ if event.isCancelled():
+ return
+ player = event.getPlayer()
+ if not hasPerm(player, permission_USE):
+ return
+ msg_limit = int(get_permission_content(player, permission_LENGTH))
+ for alias, value in data[str(uid(player))].items():
+ if player.hasPermission("essentials.chat.color"):
+ event.setMessage(event.getMessage().replace(colorify(alias), colorify(value)))
+ else:
+ event.setMessage(event.getMessage().replace(alias, value))
+ if not player.hasPermission(permission_ALL) and len(event.getMessage()) > msg_limit:
+ event.setCancelled(True)
+ plugin_header(player, "Alias")
+ msg(player, "The message you wanted to generate would exceed the length limit limit of %d. Please make it shorter!" % msg_limit)
return
- for alias, value in data[str(uid(event.getPlayer()))].items():
- if not event.getPlayer().hasPermission(permission_ALL) and len(event.getMessage()) > int(get_permission_content(event.getPlayer(), permission_LENGTH)):
- event.setCanceled(True)
- plugin_header(event.getPlayer, "Alias")
- msg(event.getPlayer(), "The message you wanted to generate would exceed your limit. Please make it shorter!")
- return
- if event.getPlayer().hasPermission("essentials.chat.color"):
- event.setMessage(event.getMessage().replace(colorify(alias), colorify(value)))
- else:
- event.setMessage(event.getMessage().replace(alias, value))
- except:
- print(trace())
def hasPerm(player, permission):
@@ -159,7 +150,7 @@ def disabled_fallback(receiver):
msg(receiver, colorify("&cUnknown command. Use &e/help&c, &e/plugins &cor ask a mod."))
else:
msg(receiver, colorify("&cPlugin alias v" + alias_version + " has experienced an &eEMERGENCY SHUTDOWN:"))
- msg(receiver, error)
+ msg(receiver, error_msg)
msg(receiver, colorify("&cPlease contact a dev/admin (especially pep :P) about this to take a look at it."))
@@ -169,11 +160,11 @@ def can_remote(player):
def add(sender, args):
plugin_header(sender, "Alias")
- if not sender.hasPermission(permission_ALL) and len(data[uid(sender)]) >= int(get_permission_content(sender, permission_AMOUNT)):
- msg(sender, "&cCould not create alias: Max_limit reached!")
- return True
+ uuid = uid(sender)
args = [args[0]] + [" ".join(args[1:])]
- if not add_alias_data(uid(sender), str(args[0]), args[1]):
+ if (args[0] not in data[uuid]) and is_alias_limit_reached(sender, sender):
+ return True
+ if not add_alias_data(uuid, str(args[0]), args[1]):
msg(sender, colorify("&c") + "Could not add this alias because it would cause some sequences to be replaced multiple times", usecolor = False)
return True
msg(sender, colorify("&7Alias: ") + args[0] + colorify("&7 -> " + args[1] + colorify("&7 was succesfully created!")), usecolor=sender.hasPermission("essentials.chat.color"))
@@ -187,20 +178,21 @@ def radd(sender, args):
sender_name = colorify(sender.getDisplayName())
else:
sender_name = colorify("&6Console")
- target = get_player(args[0])
+ target = server.getPlayer(args[0])
+ if target == None:
+ msg(sender, "&cThat player is not online")
+ return True
+ uuid = uid(target)
if args[3].lower() == "false":
plugin_header(target, "Alias")
msg(target, "&cPlayer " + sender_name + " &cis creating an alias for you!")
elif args[3].lower() != "true":
args[2] += " " + args[3]
- if not sender.hasPermission(permission_ALL) and len(data[uid(sender)]) >= int(get_permission_content(target, permission_AMOUNT)):
- msg(sender, "&cCould not create alias: Max_limit reached!")
- if args[3].lower() == "false":
- msg(target, "&cCould not create alias: Max_limit reached!")
+ if (args[1] not in data[uuid]) and is_alias_limit_reached(target, sender, args[3].lower() == "false"):
return True
if len(args) == 3:
args += ["true"]
- if not add_alias_data(uid(target), str(args[1]), str(args[2])):
+ if not add_alias_data(uuid, str(args[1]), str(args[2])):
message = colorify("&c") + "Could not add this alias because it would cause some sequences to be replaced multiple times"
msg(sender, message)
if args[3].lower() == "false":
@@ -212,6 +204,19 @@ def radd(sender, args):
return True
+def is_alias_limit_reached(player, recipient, not_silent = False):
+ if player.hasPermission(permission_ALL):
+ return False
+ alias_limit = int(get_permission_content(player, permission_AMOUNT))
+ if len(data[uid(player)]) > alias_limit:
+ message = ("&cYour limit of %d has been reached" if player is recipient else "&cThe limit of %d has been reached for that player") % alias_limit
+ msg(recipient, message)
+ if not_silent:
+ msg(player, message)
+ return True
+ return False
+
+
def add_alias_data(puuid, aliased, new_alias):
prior = data[puuid]
@@ -298,45 +303,54 @@ def remote(sender, args):
def load_data(uuid):
- try:
- load_data_thread(uuid)
-# t = threading.Thread(target=load_data_thread, args=(uuid))
-# t.daemon = True
-# t.start()
- except:
- print(trace())
-
-def load_data_thread(uuid):
if use_mysql:
- conn = zxJDBC.connect(mysql_database, mysql_user, mysql_pass, "com.mysql.jdbc.Driver")
- curs = conn.cursor()
- curs.execute("SELECT alias FROM alias WHERE uuid = ?", (uuid, ))
- results = curs.fetchall()
- if len(results) == 0:
- results = global_aliases
- curs.execute("INSERT INTO alias VALUES (?,?)", (uuid, results, ))
- data[uuid] = results
+ try:
+ t = threading.Thread(target=load_data_thread, args=(uuid,))
+ t.daemon = True
+ t.start()
+ except:
+ error(trace())
else:
data[uuid] = safe_open_json(uuid)
+def load_data_thread(uuid):
+ conn = zxJDBC.connect(mysql_database, mysql_user, mysql_pass, "com.mysql.jdbc.Driver")
+ curs = conn.cursor()
+ curs.execute("SELECT `alias` FROM `chatalias` WHERE `uuid` = ?;", (uuid, ))
+ results = curs.fetchall()
+ if len(results) == 0:
+ value = dict(global_aliases)
+ curs.execute("INSERT INTO `chatalias` VALUES (?,?);", (uuid, json_dumps(results), ))
+ conn.commit()
+ else:
+ value = json_loads(results[0][0])
+ curs.close()
+ conn.close()
+ data[uuid] = value
-def save_data(uuid):
- try:
- save_data_thread(uuid)
-# t = threading.Thread(target=save_data_thread, args=(uuid))
-# t.daemon = True
-# t.start()
- except:
- print(trace())
-def save_data_thread(uuid):
+def save_data(uuid):
if use_mysql:
- conn = zxJDBC.connect(mysql_database, mysql_user, mysql_pass, "com.mysql.jdbc.Driver")
- curs = conn.cursor()
- curs.execute("UPDATE alias SET alias = ? WHERE uuid = ?", (data[uuid], uuid, ))
+ try:
+ t = threading.Thread(target=save_data_thread, args=(uuid,))
+ t.daemon = True
+ t.start()
+ except:
+ error(trace())
else:
save_json_file("aliases/" + uuid, data[uuid])
+def save_data_thread(uuid):
+ conn = zxJDBC.connect(mysql_database, mysql_user, mysql_pass, "com.mysql.jdbc.Driver")
+ curs = conn.cursor()
+ try:
+ curs.execute("UPDATE `chatalias` SET `alias` = ? WHERE `uuid` = ?;", (json_dumps(data[uuid]), uuid, ))
+ except:
+ error(trace())
+ conn.commit()
+ curs.close()
+ conn.close()
+
# Subcommands:
subcommands = {
@@ -363,7 +377,7 @@ remotes = {
enabled = helpers_version in helpers_versions
if not enabled:
- error = colorify("&6Incompatible versions detected (&chelpers.py&6)")
+ error_msg = colorify("&6Incompatible versions detected (&chelpers.py&6)")
for player in server.getOnlinePlayers():
if enabled:
t = threading.Thread(target=load_data, args=(uid(player), ))