mirror of
https://github.com/RYGhub/royalnet.git
synced 2024-11-22 19:14:20 +00:00
✨ Add sentry integration
This commit is contained in:
parent
9348e1fb0e
commit
e5a5df672d
24 changed files with 132 additions and 7 deletions
34
poetry.lock
generated
34
poetry.lock
generated
|
@ -389,6 +389,34 @@ python-versions = ">=3.5, <4"
|
||||||
[package.dependencies]
|
[package.dependencies]
|
||||||
pyasn1 = ">=0.1.3"
|
pyasn1 = ">=0.1.3"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "sentry-sdk"
|
||||||
|
version = "1.0.0"
|
||||||
|
description = "Python client for Sentry (https://sentry.io)"
|
||||||
|
category = "main"
|
||||||
|
optional = false
|
||||||
|
python-versions = "*"
|
||||||
|
|
||||||
|
[package.dependencies]
|
||||||
|
certifi = "*"
|
||||||
|
urllib3 = ">=1.10.0"
|
||||||
|
|
||||||
|
[package.extras]
|
||||||
|
aiohttp = ["aiohttp (>=3.5)"]
|
||||||
|
beam = ["apache-beam (>=2.12)"]
|
||||||
|
bottle = ["bottle (>=0.12.13)"]
|
||||||
|
celery = ["celery (>=3)"]
|
||||||
|
chalice = ["chalice (>=1.16.0)"]
|
||||||
|
django = ["django (>=1.8)"]
|
||||||
|
falcon = ["falcon (>=1.4)"]
|
||||||
|
flask = ["flask (>=0.11)", "blinker (>=1.1)"]
|
||||||
|
pure_eval = ["pure-eval", "executing", "asttokens"]
|
||||||
|
pyspark = ["pyspark (>=2.4.4)"]
|
||||||
|
rq = ["rq (>=0.6)"]
|
||||||
|
sanic = ["sanic (>=0.8)"]
|
||||||
|
sqlalchemy = ["sqlalchemy (>=1.2)"]
|
||||||
|
tornado = ["tornado (>=5)"]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "six"
|
name = "six"
|
||||||
version = "1.15.0"
|
version = "1.15.0"
|
||||||
|
@ -540,7 +568,7 @@ multidict = ">=4.0"
|
||||||
[metadata]
|
[metadata]
|
||||||
lock-version = "1.1"
|
lock-version = "1.1"
|
||||||
python-versions = "^3.8"
|
python-versions = "^3.8"
|
||||||
content-hash = "f99a271cf9b7884b16eb47476beb88b2a20206deafbbf8d04a92885d289d1430"
|
content-hash = "2a7daab4f6b74600f4abd0696cca24d628d9c7bcc8eac455008cc547fdc126ab"
|
||||||
|
|
||||||
[metadata.files]
|
[metadata.files]
|
||||||
aiohttp = [
|
aiohttp = [
|
||||||
|
@ -948,6 +976,10 @@ rsa = [
|
||||||
{file = "rsa-4.7.2-py3-none-any.whl", hash = "sha256:78f9a9bf4e7be0c5ded4583326e7461e3a3c5aae24073648b4bdfa797d78c9d2"},
|
{file = "rsa-4.7.2-py3-none-any.whl", hash = "sha256:78f9a9bf4e7be0c5ded4583326e7461e3a3c5aae24073648b4bdfa797d78c9d2"},
|
||||||
{file = "rsa-4.7.2.tar.gz", hash = "sha256:9d689e6ca1b3038bc82bf8d23e944b6b6037bc02301a574935b2dd946e0353b9"},
|
{file = "rsa-4.7.2.tar.gz", hash = "sha256:9d689e6ca1b3038bc82bf8d23e944b6b6037bc02301a574935b2dd946e0353b9"},
|
||||||
]
|
]
|
||||||
|
sentry-sdk = [
|
||||||
|
{file = "sentry-sdk-1.0.0.tar.gz", hash = "sha256:71de00c9711926816f750bc0f57ef2abbcb1bfbdf5378c601df7ec978f44857a"},
|
||||||
|
{file = "sentry_sdk-1.0.0-py2.py3-none-any.whl", hash = "sha256:9221e985f425913204989d0e0e1cbb719e8b7fa10540f1bc509f660c06a34e66"},
|
||||||
|
]
|
||||||
six = [
|
six = [
|
||||||
{file = "six-1.15.0-py2.py3-none-any.whl", hash = "sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"},
|
{file = "six-1.15.0-py2.py3-none-any.whl", hash = "sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"},
|
||||||
{file = "six-1.15.0.tar.gz", hash = "sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259"},
|
{file = "six-1.15.0.tar.gz", hash = "sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259"},
|
||||||
|
|
|
@ -30,6 +30,7 @@ colour = "^0.1.5"
|
||||||
royalspells = "^3.2"
|
royalspells = "^3.2"
|
||||||
async-timeout = "^3.0.1"
|
async-timeout = "^3.0.1"
|
||||||
royalnet-discordpy = "~0.5.8"
|
royalnet-discordpy = "~0.5.8"
|
||||||
|
sentry-sdk = "^1.0.0"
|
||||||
|
|
||||||
[tool.poetry.dev-dependencies]
|
[tool.poetry.dev-dependencies]
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import discord
|
import discord
|
||||||
|
import pkg_resources
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import royalnet.scrolls as sc
|
import royalnet.scrolls as sc
|
||||||
import royalnet_telethon as rt
|
import royalnet_telethon as rt
|
||||||
|
@ -6,13 +7,36 @@ import royalnet_discordpy as rd
|
||||||
import pathlib
|
import pathlib
|
||||||
import re
|
import re
|
||||||
import coloredlogs
|
import coloredlogs
|
||||||
|
import sentry_sdk
|
||||||
|
import sentry_sdk.integrations.atexit
|
||||||
|
import sentry_sdk.integrations.dedupe
|
||||||
|
import sentry_sdk.integrations.modules
|
||||||
|
import sentry_sdk.integrations.threading
|
||||||
|
import logging
|
||||||
|
|
||||||
from . import commands
|
from . import commands
|
||||||
from .database import engine, base
|
from .database import engine, base
|
||||||
|
|
||||||
coloredlogs.install(level="DEBUG", isatty=True)
|
coloredlogs.install(level="DEBUG" if __debug__ else "INFO", isatty=True)
|
||||||
config = sc.Scroll.from_file(namespace="ROYALPACK", file_path=pathlib.Path("royalpack.cfg.toml"))
|
config = sc.Scroll.from_file(namespace="ROYALPACK", file_path=pathlib.Path("royalpack.cfg.toml"))
|
||||||
|
|
||||||
|
if dsn := config.get("sentry.dsn", None):
|
||||||
|
logging.info("Enabling Sentry...")
|
||||||
|
sentry_sdk.init(
|
||||||
|
dsn=dsn,
|
||||||
|
debug=__debug__,
|
||||||
|
release=pkg_resources.get_distribution("royalpack").version,
|
||||||
|
environment="Development" if __debug__ else "Production",
|
||||||
|
default_integrations=False,
|
||||||
|
integrations=[
|
||||||
|
sentry_sdk.integrations.atexit.AtexitIntegration(),
|
||||||
|
sentry_sdk.integrations.dedupe.DedupeIntegration(),
|
||||||
|
sentry_sdk.integrations.modules.ModulesIntegration(),
|
||||||
|
sentry_sdk.integrations.threading.ThreadingIntegration(),
|
||||||
|
],
|
||||||
|
traces_sample_rate=1.0
|
||||||
|
)
|
||||||
|
|
||||||
engine_ = engine.lazy_engine.evaluate()
|
engine_ = engine.lazy_engine.evaluate()
|
||||||
base.Base.metadata.create_all(engine_)
|
base.Base.metadata.create_all(engine_)
|
||||||
|
|
||||||
|
|
|
@ -1,2 +1,3 @@
|
||||||
from .login import *
|
from .login import *
|
||||||
from .target import *
|
from .target import *
|
||||||
|
from .sentry import *
|
||||||
|
|
29
royalpack/bolts/sentry.py
Normal file
29
royalpack/bolts/sentry.py
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
"""
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
from __future__ import annotations
|
||||||
|
|
||||||
|
import functools
|
||||||
|
import logging
|
||||||
|
import sentry_sdk
|
||||||
|
|
||||||
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
def capture_errors(f):
|
||||||
|
@functools.wraps(f)
|
||||||
|
async def decorated(**f_kwargs):
|
||||||
|
try:
|
||||||
|
return await f(**f_kwargs)
|
||||||
|
except Exception as e:
|
||||||
|
log.error(f"Captured error: {e!r}")
|
||||||
|
if sentry_sdk.Hub.current is not None:
|
||||||
|
sentry_sdk.capture_exception(error=e)
|
||||||
|
|
||||||
|
return decorated
|
||||||
|
|
||||||
|
|
||||||
|
__all__ = (
|
||||||
|
"capture_errors",
|
||||||
|
)
|
|
@ -1,6 +1,8 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def ahnonlosoio(*, _msg: engi.Message, **__):
|
async def ahnonlosoio(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import royalnet.engineer.conversation as c
|
import royalpack.bolts as rb
|
||||||
import datetime
|
import datetime
|
||||||
import random
|
import random
|
||||||
|
|
||||||
|
@ -73,6 +73,7 @@ ANSWERS = [
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def answer(*, _msg: engi.Message, **__):
|
async def answer(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -3,10 +3,12 @@ import logging
|
||||||
|
|
||||||
import aiohttp
|
import aiohttp
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def cat(*, _msg: engi.Message, **__):
|
async def cat(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import royalnet.engineer.conversation as c
|
|
||||||
import royalnet_telethon
|
import royalnet_telethon
|
||||||
import royalnet_telethon.bullet.contents
|
import royalnet_telethon.bullet.contents
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def ciaoruozi(*, _msg: engi.Message, _imp, **__):
|
async def ciaoruozi(*, _msg: engi.Message, _imp, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def color(*, _msg: engi.Message, **__):
|
async def color(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
import royalnet.royaltyping as t
|
import royalnet.royaltyping as t
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import royalnet_discordpy as rd
|
import royalnet_discordpy as rd
|
||||||
|
import royalpack.bolts as rb
|
||||||
import discord
|
import discord
|
||||||
import discord.channel
|
import discord.channel
|
||||||
import itertools
|
import itertools
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def cv(*, _msg: engi.Message, _pda: engi.PDA, **__):
|
async def cv(*, _msg: engi.Message, _pda: engi.PDA, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -2,8 +2,10 @@ import io
|
||||||
|
|
||||||
import aiohttp
|
import aiohttp
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def dog_any(*, _msg: engi.Message, **__):
|
async def dog_any(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
import random
|
import random
|
||||||
|
|
||||||
|
|
||||||
|
@ -79,6 +80,7 @@ _emojis = {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def emojify(*, _msg: engi.Message, message: str, **__):
|
async def emojify(*, _msg: engi.Message, message: str, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -7,6 +7,7 @@ import functools
|
||||||
import arrow
|
import arrow
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.use_ryglogin(allow_anonymous=False)
|
@rb.use_ryglogin(allow_anonymous=False)
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
|
@ -18,6 +19,7 @@ async def fiorygi_balance_self(*, _user: db.User, _msg: engi.Message, **__):
|
||||||
await _msg.reply(text=f"💰 Attualmente, possiedi \uE01Bƒ {_user.fiorygi}\uE00B.")
|
await _msg.reply(text=f"💰 Attualmente, possiedi \uE01Bƒ {_user.fiorygi}\uE00B.")
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.with_target()
|
@rb.with_target()
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
|
@ -51,6 +53,7 @@ def render(transaction: db.Transaction, user: db.User):
|
||||||
return " - ".join(row)
|
return " - ".join(row)
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.use_ryglogin(allow_anonymous=False)
|
@rb.use_ryglogin(allow_anonymous=False)
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
|
@ -79,6 +82,7 @@ async def fiorygi_transactions_self(*, _session: db.SessionType, _user: db.User,
|
||||||
await _msg.reply(text="\n\n".join(msg))
|
await _msg.reply(text="\n\n".join(msg))
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.with_target()
|
@rb.with_target()
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
|
@ -107,6 +111,7 @@ async def fiorygi_transactions_other(*, _session: db.SessionType, _target: db.Us
|
||||||
await _msg.reply(text="\n\n".join(msg))
|
await _msg.reply(text="\n\n".join(msg))
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.use_ryglogin(allow_anonymous=False)
|
@rb.use_ryglogin(allow_anonymous=False)
|
||||||
@rb.with_target()
|
@rb.with_target()
|
||||||
|
@ -153,6 +158,7 @@ async def fiorygi_give(
|
||||||
await _msg.reply(text=f"💸 Hai trasferito \uE01Bƒ {amount}\uE00B a {_target}.")
|
await _msg.reply(text=f"💸 Hai trasferito \uE01Bƒ {amount}\uE00B a {_target}.")
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.use_ryglogin(allow_anonymous=False)
|
@rb.use_ryglogin(allow_anonymous=False)
|
||||||
@rb.with_target()
|
@rb.with_target()
|
||||||
|
@ -199,6 +205,7 @@ async def fiorygi_magick(
|
||||||
await _msg.reply(text=f"🏦 Hai modificato il portafoglio di {_target} di \uE01Bƒ {amount}\uE00B.")
|
await _msg.reply(text=f"🏦 Hai modificato il portafoglio di {_target} di \uE01Bƒ {amount}\uE00B.")
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.use_ryglogin(allow_anonymous=False)
|
@rb.use_ryglogin(allow_anonymous=False)
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
|
@ -251,6 +258,7 @@ async def fiorygi_dig(
|
||||||
await _msg.reply(text=f"🏖 Hai trovato un tesoro nascosto dal valore di \uE01Bƒ {treasure.value}\uE00B!")
|
await _msg.reply(text=f"🏖 Hai trovato un tesoro nascosto dal valore di \uE01Bƒ {treasure.value}\uE00B!")
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.use_ryglogin(allow_anonymous=False)
|
@rb.use_ryglogin(allow_anonymous=False)
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import random
|
import random
|
||||||
import datetime
|
import datetime
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
# Tutte le fortunes qui devono essere positive :)
|
# Tutte le fortunes qui devono essere positive :)
|
||||||
|
@ -56,6 +57,7 @@ _fortunes = [
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def fortune(*, _msg: engi.Message, **__):
|
async def fortune(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -6,6 +6,7 @@ import royalpack.database as db
|
||||||
import royalpack.config as cfg
|
import royalpack.config as cfg
|
||||||
import royalnet_telethon.bullet.contents
|
import royalnet_telethon.bullet.contents
|
||||||
import royalnet_discordpy
|
import royalnet_discordpy
|
||||||
|
import royalpack.bolts as rb
|
||||||
import aiohttp
|
import aiohttp
|
||||||
import asyncio
|
import asyncio
|
||||||
import logging
|
import logging
|
||||||
|
@ -15,9 +16,7 @@ import async_timeout
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
# FIXME: Properly handle errors in this function!
|
@rb.capture_errors
|
||||||
|
|
||||||
|
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def login(*, _msg: engi.Message, _session: so.Session, _imp, **__):
|
async def login(*, _msg: engi.Message, _session: so.Session, _imp, **__):
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def man(*, _msg: engi.Message, _router: engi.Router, commandname: str, **__):
|
async def man(*, _msg: engi.Message, _router: engi.Router, commandname: str, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def ping(*, _msg: engi.Message, **__):
|
async def ping(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def pmots(*, _msg: engi.Message, **__):
|
async def pmots(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
import logging
|
import logging
|
||||||
import re
|
import re
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def ship(*, _msg: engi.Message, first: str, second: str, **__):
|
async def ship(*, _msg: engi.Message, first: str, second: str, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import random
|
import random
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
_ds_list = ["della secca", "del seccatore", "del secchiello", "del secchio", "del secchione", "del secondino",
|
_ds_list = ["della secca", "del seccatore", "del secchiello", "del secchio", "del secchione", "del secondino",
|
||||||
|
@ -54,6 +55,7 @@ _ds_list = ["della secca", "del seccatore", "del secchiello", "del secchio", "de
|
||||||
"della Stampante"]
|
"della Stampante"]
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def smecds(*, _msg: engi.Message, **__):
|
async def smecds(*, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import royalspells
|
import royalspells
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def spell(*, _msg: engi.Message, spellname: str, **__):
|
async def spell(*, _msg: engi.Message, spellname: str, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
import royalnet.engineer as engi
|
import royalnet.engineer as engi
|
||||||
import royalnet_telethon as rt
|
import royalnet_telethon as rt
|
||||||
import pkg_resources
|
import pkg_resources
|
||||||
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
async def version(*, _imp: engi.PDAImplementation, _msg: engi.Message, **__):
|
async def version(*, _imp: engi.PDAImplementation, _msg: engi.Message, **__):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -3,6 +3,7 @@ import royalpack.database as db
|
||||||
import royalpack.bolts as rb
|
import royalpack.bolts as rb
|
||||||
|
|
||||||
|
|
||||||
|
@rb.capture_errors
|
||||||
@engi.use_database(db.lazy_session_class)
|
@engi.use_database(db.lazy_session_class)
|
||||||
@rb.use_ryglogin(allow_anonymous=True)
|
@rb.use_ryglogin(allow_anonymous=True)
|
||||||
@engi.TeleportingConversation
|
@engi.TeleportingConversation
|
||||||
|
|
Loading…
Reference in a new issue