mirror of
https://gitlab.com/chicken-riders/RcGcDw.git
synced 2025-02-23 00:24:09 +00:00
Added datadump extension log support, moved translation strings
This commit is contained in:
parent
25f28c5f6c
commit
61d7e34575
|
@ -15,3 +15,6 @@
|
||||||
|
|
||||||
import extensions.base.mediawiki
|
import extensions.base.mediawiki
|
||||||
import extensions.base.abusefilter
|
import extensions.base.abusefilter
|
||||||
|
import extensions.base.managewiki
|
||||||
|
import extensions.base.cargo
|
||||||
|
import extensions.base.datadump
|
73
extensions/base/datadump.py
Normal file
73
extensions/base/datadump.py
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
# This file is part of Recent changes Goat compatible Discord webhook (RcGcDw).
|
||||||
|
#
|
||||||
|
# RcGcDw is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# RcGcDw is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with RcGcDw. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
|
||||||
|
import logging
|
||||||
|
from src.discord.message import DiscordMessage
|
||||||
|
from src.api import formatter
|
||||||
|
from src.i18n import rc_formatters
|
||||||
|
from src.api.context import Context
|
||||||
|
from src.api.util import embed_helper, compact_author, create_article_path, sanitize_to_markdown, sanitize_to_url
|
||||||
|
|
||||||
|
_ = rc_formatters.gettext
|
||||||
|
ngettext = rc_formatters.ngettext
|
||||||
|
|
||||||
|
|
||||||
|
# DataDumps - https://www.mediawiki.org/wiki/Extension:DataDump
|
||||||
|
# datadump/generate - Generating a dump of wiki
|
||||||
|
|
||||||
|
|
||||||
|
@formatter.embed(event="datadump/generate")
|
||||||
|
def embed_datadump_generate(ctx: Context, change: dict) -> DiscordMessage:
|
||||||
|
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
||||||
|
embed_helper(ctx, embed, change)
|
||||||
|
embed["title"] = _("Generated {file} dump").format(file=change["logparams"]["filename"])
|
||||||
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
|
return embed
|
||||||
|
|
||||||
|
|
||||||
|
@formatter.compact(event="mdatadump/generate")
|
||||||
|
def compact_datadump_generate(ctx: Context, change: dict):
|
||||||
|
author, author_url = compact_author(ctx, change)
|
||||||
|
parsed_comment = "" if ctx.parsedcomment is None else " *(" + ctx.parsedcomment + ")*"
|
||||||
|
content = _("[{author}]({author_url}) generated *{file}* dump{comment}").format(
|
||||||
|
author=author, author_url=author_url, file=change["logparams"]["filename"],
|
||||||
|
comment=parsed_comment
|
||||||
|
)
|
||||||
|
return DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url, content=content)
|
||||||
|
|
||||||
|
# datadump/delete - Deleting a dump of a wiki
|
||||||
|
|
||||||
|
|
||||||
|
@formatter.embed(event="datadump/delete")
|
||||||
|
def embed_datadump_delete(ctx: Context, change: dict) -> DiscordMessage:
|
||||||
|
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
||||||
|
embed_helper(ctx, embed, change)
|
||||||
|
embed["title"] = _("Deleted {file} dump").format(file=change["logparams"]["filename"])
|
||||||
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
|
return embed
|
||||||
|
|
||||||
|
|
||||||
|
@formatter.compact(event="mdatadump/delete")
|
||||||
|
def compact_datadump_delete(ctx: Context, change: dict) -> DiscordMessage:
|
||||||
|
author, author_url = compact_author(ctx, change)
|
||||||
|
parsed_comment = "" if ctx.parsedcomment is None else " *(" + ctx.parsedcomment + ")*"
|
||||||
|
content = _("[{author}]({author_url}) deleted *{file}* dump{comment}").format(
|
||||||
|
author=author, author_url=author_url, file=change["logparams"]["filename"],
|
||||||
|
comment=parsed_comment
|
||||||
|
)
|
||||||
|
return DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url, content=content)
|
|
@ -14,7 +14,6 @@
|
||||||
# along with RcGcDw. If not, see <http://www.gnu.org/licenses/>.
|
# along with RcGcDw. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
import re
|
|
||||||
from src.discord.message import DiscordMessage
|
from src.discord.message import DiscordMessage
|
||||||
from src.api import formatter
|
from src.api import formatter
|
||||||
from src.i18n import rc_formatters
|
from src.i18n import rc_formatters
|
||||||
|
@ -34,6 +33,7 @@ def embed_managewiki_settings(ctx: Context, change: dict):
|
||||||
embed_helper(ctx, embed, change)
|
embed_helper(ctx, embed, change)
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
embed["title"] = _("Changed wiki settings")
|
embed["title"] = _("Changed wiki settings")
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
if change["logparams"].get("changes", ""):
|
if change["logparams"].get("changes", ""):
|
||||||
embed.add_field("Setting", sanitize_to_markdown(change["logparams"].get("changes")))
|
embed.add_field("Setting", sanitize_to_markdown(change["logparams"].get("changes")))
|
||||||
return embed
|
return embed
|
||||||
|
@ -53,6 +53,7 @@ def compact_managewiki_settings(ctx: Context, change: dict):
|
||||||
def embed_managewiki_delete(ctx: Context, change: dict):
|
def embed_managewiki_delete(ctx: Context, change: dict):
|
||||||
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
||||||
embed_helper(ctx, embed, change)
|
embed_helper(ctx, embed, change)
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
embed["title"] = _("Deleted a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
embed["title"] = _("Deleted a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
||||||
return embed
|
return embed
|
||||||
|
@ -77,6 +78,7 @@ def compact_managewiki_delete(ctx: Context, change: dict):
|
||||||
def embed_managewiki_lock(ctx: Context, change: dict):
|
def embed_managewiki_lock(ctx: Context, change: dict):
|
||||||
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
||||||
embed_helper(ctx, embed, change)
|
embed_helper(ctx, embed, change)
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
embed["title"] = _("Locked a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
embed["title"] = _("Locked a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
||||||
return embed
|
return embed
|
||||||
|
@ -101,6 +103,7 @@ def embed_managewiki_namespaces(ctx: Context, change: dict):
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
embed["title"] = _("Modified \"{namespace_name}\" namespace").format(
|
embed["title"] = _("Modified \"{namespace_name}\" namespace").format(
|
||||||
namespace_name=change["logparams"].get("namespace", _("Unknown")))
|
namespace_name=change["logparams"].get("namespace", _("Unknown")))
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
embed.add_field(_('Wiki'), change["logparams"].get("wiki", _("Unknown")))
|
embed.add_field(_('Wiki'), change["logparams"].get("wiki", _("Unknown")))
|
||||||
return embed
|
return embed
|
||||||
|
|
||||||
|
@ -124,6 +127,7 @@ def embed_managewiki_namespaces_delete(ctx: Context, change: dict):
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
embed["title"] = _("Deleted a \"{namespace_name}\" namespace").format(
|
embed["title"] = _("Deleted a \"{namespace_name}\" namespace").format(
|
||||||
namespace_name=change["logparams"].get("namespace", _("Unknown")))
|
namespace_name=change["logparams"].get("namespace", _("Unknown")))
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
embed.add_field(_('Wiki'), change["logparams"].get("wiki", _("Unknown")))
|
embed.add_field(_('Wiki'), change["logparams"].get("wiki", _("Unknown")))
|
||||||
return embed
|
return embed
|
||||||
|
|
||||||
|
@ -148,6 +152,7 @@ def embed_managewiki_rights(ctx: Context, change: dict):
|
||||||
embed_helper(ctx, embed, change)
|
embed_helper(ctx, embed, change)
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
group_name = change["title"].split("/permissions/", 1)[1]
|
group_name = change["title"].split("/permissions/", 1)[1]
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
embed["title"] = _("Modified \"{usergroup_name}\" usergroup").format(usergroup_name=group_name)
|
embed["title"] = _("Modified \"{usergroup_name}\" usergroup").format(usergroup_name=group_name)
|
||||||
return embed
|
return embed
|
||||||
|
|
||||||
|
@ -170,6 +175,7 @@ def embed_managewiki_undelete(ctx: Context, change: dict):
|
||||||
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
||||||
embed_helper(ctx, embed, change)
|
embed_helper(ctx, embed, change)
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
embed["title"] = _("Undeleted a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
embed["title"] = _("Undeleted a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
||||||
return embed
|
return embed
|
||||||
|
|
||||||
|
@ -192,6 +198,7 @@ def embed_managewiki_unlock(ctx: Context, change: dict):
|
||||||
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
embed = DiscordMessage(ctx.message_type, ctx.event, ctx.webhook_url)
|
||||||
embed_helper(ctx, embed, change)
|
embed_helper(ctx, embed, change)
|
||||||
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
embed["url"] = create_article_path(sanitize_to_url(change["title"]))
|
||||||
|
embed["description"] = ctx.parsedcomment
|
||||||
embed["title"] = _("Unlocked a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
embed["title"] = _("Unlocked a \"{wiki}\" wiki").format(wiki=change["logparams"].get("wiki", _("Unknown")))
|
||||||
return embed
|
return embed
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,10 @@ ngettext = rc_formatters.ngettext
|
||||||
|
|
||||||
logger = logging.getLogger("extensions.base")
|
logger = logging.getLogger("extensions.base")
|
||||||
|
|
||||||
|
if 1 == 2: # additional translation strings in unreachable code
|
||||||
|
print(_("director"), _("bot"), _("editor"), _("directors"), _("sysop"), _("bureaucrat"), _("reviewer"),
|
||||||
|
_("autoreview"), _("autopatrol"), _("wiki_guardian"))
|
||||||
|
|
||||||
# Page edit - event edit, New - page creation
|
# Page edit - event edit, New - page creation
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -51,6 +51,12 @@ display_mode = settings.get("fandom_discussions", {}).get("appearance", {}).get(
|
||||||
webhook_url =settings.get("fandom_discussions", {}).get("webhookURL", settings.get("webhookURL"))
|
webhook_url =settings.get("fandom_discussions", {}).get("webhookURL", settings.get("webhookURL"))
|
||||||
|
|
||||||
|
|
||||||
|
def inject_client(client_obj):
|
||||||
|
"""Function to avoid circular import issues"""
|
||||||
|
global client
|
||||||
|
client = client_obj
|
||||||
|
|
||||||
|
|
||||||
def fetch_discussions():
|
def fetch_discussions():
|
||||||
messagequeue.resend_msgs()
|
messagequeue.resend_msgs()
|
||||||
request = safe_request(fetch_url)
|
request = safe_request(fetch_url)
|
||||||
|
@ -118,10 +124,6 @@ def parse_discussion_post(post, comment_pages):
|
||||||
send_to_discord(message, meta=DiscordMessageMetadata("POST"))
|
send_to_discord(message, meta=DiscordMessageMetadata("POST"))
|
||||||
|
|
||||||
|
|
||||||
def inject_client(client_obj):
|
|
||||||
global client
|
|
||||||
client = client_obj
|
|
||||||
|
|
||||||
def safe_request(url):
|
def safe_request(url):
|
||||||
"""Function to assure safety of request, and do not crash the script on exceptions,"""
|
"""Function to assure safety of request, and do not crash the script on exceptions,"""
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -261,15 +261,8 @@ def compact_formatter(action, change, parsed_comment, categories, recent_changes
|
||||||
elif action == "managewiki/unlock":
|
elif action == "managewiki/unlock":
|
||||||
|
|
||||||
elif action == "datadump/generate":
|
elif action == "datadump/generate":
|
||||||
content = _("[{author}]({author_url}) generated *{file}* dump{comment}").format(
|
|
||||||
author=author, author_url=author_url, file=change["logparams"]["filename"],
|
|
||||||
comment=parsed_comment
|
|
||||||
)
|
|
||||||
elif action == "datadump/delete":
|
elif action == "datadump/delete":
|
||||||
content = _("[{author}]({author_url}) deleted *{file}* dump{comment}").format(
|
|
||||||
author=author, author_url=author_url, file=change["logparams"]["filename"],
|
|
||||||
comment=parsed_comment
|
|
||||||
)
|
|
||||||
elif action == "pagetranslation/mark":
|
elif action == "pagetranslation/mark":
|
||||||
link = create_article_path(change["title"])
|
link = create_article_path(change["title"])
|
||||||
if "?" in link:
|
if "?" in link:
|
||||||
|
@ -621,11 +614,8 @@ def embed_formatter(action, change, parsed_comment, categories, recent_changes):
|
||||||
elif action == "managewiki/unlock":
|
elif action == "managewiki/unlock":
|
||||||
|
|
||||||
elif action == "datadump/generate":
|
elif action == "datadump/generate":
|
||||||
embed["title"] = _("Generated {file} dump").format(file=change["logparams"]["filename"])
|
|
||||||
link = create_article_path(change["title"])
|
|
||||||
elif action == "datadump/delete":
|
elif action == "datadump/delete":
|
||||||
embed["title"] = _("Deleted {file} dump").format(file=change["logparams"]["filename"])
|
|
||||||
link = create_article_path(change["title"])
|
|
||||||
elif action == "pagetranslation/mark":
|
elif action == "pagetranslation/mark":
|
||||||
link = create_article_path(change["title"])
|
link = create_article_path(change["title"])
|
||||||
if "?" in link:
|
if "?" in link:
|
||||||
|
|
|
@ -336,9 +336,6 @@ if settings["rc_enabled"]:
|
||||||
else:
|
else:
|
||||||
logger.info("Script started! RC is disabled however, this means no recent changes will be sent :c")
|
logger.info("Script started! RC is disabled however, this means no recent changes will be sent :c")
|
||||||
|
|
||||||
if 1 == 2: # additional translation strings in unreachable code
|
|
||||||
print(_("director"), _("bot"), _("editor"), _("directors"), _("sysop"), _("bureaucrat"), _("reviewer"),
|
|
||||||
_("autoreview"), _("autopatrol"), _("wiki_guardian"), ngettext("second", "seconds", 1), ngettext("minute", "minutes", 1), ngettext("hour", "hours", 1), ngettext("day", "days", 1), ngettext("week", "weeks", 1), ngettext("month", "months",1), ngettext("year", "years", 1), ngettext("millennium", "millennia", 1), ngettext("decade", "decades", 1), ngettext("century", "centuries", 1))
|
|
||||||
# noinspection PyUnreachableCode
|
# noinspection PyUnreachableCode
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue