Compare commits

..

No commits in common. "master" and "v0.5.2" have entirely different histories.

8 changed files with 14 additions and 43 deletions

View file

@ -10,7 +10,7 @@ default:
- docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
build frontend:
image: node:24-alpine
image: node:22-alpine
stage: build frontend
before_script: []
variables:

View file

@ -1,9 +1,9 @@
FROM node:24 AS frontend-builder
FROM node:22 AS frontend-builder
COPY ./maubot/management/frontend /frontend
RUN cd /frontend && yarn --prod && yarn build
FROM alpine:3.22
FROM alpine:3.21
RUN apk add --no-cache \
python3 py3-pip py3-setuptools py3-wheel \
@ -11,8 +11,6 @@ RUN apk add --no-cache \
su-exec \
yq \
py3-aiohttp \
py3-aiodns \
py3-brotli \
py3-attrs \
py3-bcrypt \
py3-cffi \

View file

@ -1,4 +1,4 @@
FROM alpine:3.22
FROM alpine:3.21
RUN apk add --no-cache \
python3 py3-pip py3-setuptools py3-wheel \

View file

@ -350,8 +350,6 @@ class Client(DBClient):
}
async def _handle_tombstone(self, evt: StateEvent) -> None:
if evt.state_key != "":
return
if not evt.content.replacement_room:
self.log.info(f"{evt.room_id} tombstoned with no replacement, ignoring")
return
@ -372,10 +370,7 @@ class Client(DBClient):
_, server = self.client.parse_user_id(evt.sender)
room_id = await self.client.join_room(evt.content.replacement_room, servers=[server])
power_levels = await self.client.get_state_event(room_id, EventType.ROOM_POWER_LEVELS)
create_event = await self.client.get_state_event(
room_id, EventType.ROOM_CREATE, format="event"
)
if power_levels.get_user_level(evt.sender, create_event) < power_levels.invite:
if power_levels.get_user_level(evt.sender) < power_levels.invite:
self.log.warning(
f"{evt.room_id} was tombstoned into {room_id} by {evt.sender},"
" but the sender doesn't have invite power levels, leaving..."
@ -504,14 +499,8 @@ class Client(DBClient):
self.start_sync()
async def _update_remote_profile(self) -> None:
try:
profile = await self.client.get_profile(self.id)
self.remote_displayname, self.remote_avatar_url = (
profile.displayname,
profile.avatar_url,
)
except Exception:
self.log.warning("Failed to update own profile from server", exc_info=True)
profile = await self.client.get_profile(self.id)
self.remote_displayname, self.remote_avatar_url = profile.displayname, profile.avatar_url
async def delete(self) -> None:
try:

View file

@ -54,8 +54,7 @@ server:
port: 29316
# Public base URL where the server is visible.
public_url: https://example.com
# The base path for the UI. Note that this does not change the API path.
# Add a path prefix to public_url if you want everything on a subpath.
# The base path for the UI.
ui_base_path: /_matrix/maubot
# The base path for plugin endpoints. The instance ID will be appended directly.
plugin_base_path: /_matrix/maubot/plugin/

View file

@ -70,9 +70,9 @@ class Client extends BaseMainView {
get initialState() {
return {
id: "",
displayname: "disable",
displayname: "",
homeserver: "",
avatar_url: "disable",
avatar_url: "",
access_token: "",
device_id: "",
fingerprint: null,

View file

@ -15,7 +15,7 @@
# along with this program. If not, see <https://www.gnu.org/licenses/>.
from __future__ import annotations
from typing import Any, Awaitable
from typing import Awaitable
from html import escape
import asyncio
@ -63,7 +63,7 @@ async def parse_formatted(
else:
return message, escape(message)
text = (await MaubotHTMLParser().parse(html)).text
if len(text) > 100 and len(text) + len(html) > 40000:
if len(text) + len(html) > 60000:
text = text[:100] + "[long message cut off]"
return text, html
@ -88,7 +88,6 @@ class MaubotMessageEvent(MessageEvent):
reply: bool | str = False,
in_thread: bool | None = None,
edits: EventID | MessageEvent | None = None,
extra_content: dict[str, Any] | None = None,
) -> EventID:
"""
Respond to the message.
@ -108,7 +107,6 @@ class MaubotMessageEvent(MessageEvent):
the root if necessary.
edits: An event ID or MessageEvent to edit. If set, the reply and in_thread parameters
are ignored, as edits can't change the reply or thread status.
extra_content: Extra content to add to the event.
Returns:
The ID of the response event.
@ -145,9 +143,6 @@ class MaubotMessageEvent(MessageEvent):
)
else:
content.set_reply(self)
if extra_content:
for k, v in extra_content.items():
content[k] = v
return await self.client.send_message_event(self.room_id, event_type, content)
def reply(
@ -157,7 +152,6 @@ class MaubotMessageEvent(MessageEvent):
markdown: bool = True,
allow_html: bool = False,
in_thread: bool | None = None,
extra_content: dict[str, Any] | None = None,
) -> Awaitable[EventID]:
"""
Reply to the message. The parameters are the same as :meth:`respond`,
@ -175,7 +169,6 @@ class MaubotMessageEvent(MessageEvent):
thread. If set to ``False``, the response will never be in a thread. If set to
``True``, the response will always be in a thread, creating one with this event as
the root if necessary.
extra_content: Extra content to add to the event.
Returns:
The ID of the response event.
@ -187,7 +180,6 @@ class MaubotMessageEvent(MessageEvent):
reply=True,
in_thread=in_thread,
allow_html=allow_html,
extra_content=extra_content,
)
def mark_read(self) -> Awaitable[None]:
@ -264,18 +256,14 @@ class MaubotMatrixClient(MatrixClient):
markdown: str,
*,
allow_html: bool = False,
render_markdown: bool = True,
msgtype: MessageType = MessageType.TEXT,
edits: EventID | MessageEvent | None = None,
relates_to: RelatesTo | None = None,
extra_content: dict[str, Any] = None,
**kwargs,
) -> EventID:
content = TextMessageEventContent(msgtype=msgtype, format=Format.HTML)
content.body, content.formatted_body = await parse_formatted(
markdown,
allow_html=allow_html,
render_markdown=render_markdown,
markdown, allow_html=allow_html
)
if relates_to:
if edits:
@ -283,9 +271,6 @@ class MaubotMatrixClient(MatrixClient):
content.relates_to = relates_to
elif edits:
content.set_edit(edits)
if extra_content:
for k, v in extra_content.items():
content[k] = v
return await self.send_message(room_id, content, **kwargs)
def dispatch_event(self, event: Event, source: SyncStream) -> list[asyncio.Task]:

View file

@ -1,4 +1,4 @@
mautrix>=0.20.9rc3,<0.21
mautrix>=0.20.7,<0.21
aiohttp>=3,<4
yarl>=1,<2
asyncpg>=0.20,<1