mirror of
https://git.anonymousland.org/anonymousland/synapse-product.git
synced 2024-12-17 14:24:21 -05:00
Annotate string constants in synapse.api.constants
with Final
(#11356)
This change makes mypy complain if the constants are ever reassigned, and, more usefully, makes mypy type them as `Literal`s instead of `str`s, allowing code of the following form to pass mypy: ```py def do_something(membership: Literal["join", "leave"], ...): ... do_something(Membership.JOIN, ...) ```
This commit is contained in:
parent
0d88c4f903
commit
7862f821de
1
changelog.d/11356.misc
Normal file
1
changelog.d/11356.misc
Normal file
@ -0,0 +1 @@
|
|||||||
|
Add `Final` annotation to string constants in `synapse.api.constants` so that they get typed as `Literal`s.
|
@ -17,6 +17,8 @@
|
|||||||
|
|
||||||
"""Contains constants from the specification."""
|
"""Contains constants from the specification."""
|
||||||
|
|
||||||
|
from typing_extensions import Final
|
||||||
|
|
||||||
# the max size of a (canonical-json-encoded) event
|
# the max size of a (canonical-json-encoded) event
|
||||||
MAX_PDU_SIZE = 65536
|
MAX_PDU_SIZE = 65536
|
||||||
|
|
||||||
@ -39,125 +41,125 @@ class Membership:
|
|||||||
|
|
||||||
"""Represents the membership states of a user in a room."""
|
"""Represents the membership states of a user in a room."""
|
||||||
|
|
||||||
INVITE = "invite"
|
INVITE: Final = "invite"
|
||||||
JOIN = "join"
|
JOIN: Final = "join"
|
||||||
KNOCK = "knock"
|
KNOCK: Final = "knock"
|
||||||
LEAVE = "leave"
|
LEAVE: Final = "leave"
|
||||||
BAN = "ban"
|
BAN: Final = "ban"
|
||||||
LIST = (INVITE, JOIN, KNOCK, LEAVE, BAN)
|
LIST: Final = (INVITE, JOIN, KNOCK, LEAVE, BAN)
|
||||||
|
|
||||||
|
|
||||||
class PresenceState:
|
class PresenceState:
|
||||||
"""Represents the presence state of a user."""
|
"""Represents the presence state of a user."""
|
||||||
|
|
||||||
OFFLINE = "offline"
|
OFFLINE: Final = "offline"
|
||||||
UNAVAILABLE = "unavailable"
|
UNAVAILABLE: Final = "unavailable"
|
||||||
ONLINE = "online"
|
ONLINE: Final = "online"
|
||||||
BUSY = "org.matrix.msc3026.busy"
|
BUSY: Final = "org.matrix.msc3026.busy"
|
||||||
|
|
||||||
|
|
||||||
class JoinRules:
|
class JoinRules:
|
||||||
PUBLIC = "public"
|
PUBLIC: Final = "public"
|
||||||
KNOCK = "knock"
|
KNOCK: Final = "knock"
|
||||||
INVITE = "invite"
|
INVITE: Final = "invite"
|
||||||
PRIVATE = "private"
|
PRIVATE: Final = "private"
|
||||||
# As defined for MSC3083.
|
# As defined for MSC3083.
|
||||||
RESTRICTED = "restricted"
|
RESTRICTED: Final = "restricted"
|
||||||
|
|
||||||
|
|
||||||
class RestrictedJoinRuleTypes:
|
class RestrictedJoinRuleTypes:
|
||||||
"""Understood types for the allow rules in restricted join rules."""
|
"""Understood types for the allow rules in restricted join rules."""
|
||||||
|
|
||||||
ROOM_MEMBERSHIP = "m.room_membership"
|
ROOM_MEMBERSHIP: Final = "m.room_membership"
|
||||||
|
|
||||||
|
|
||||||
class LoginType:
|
class LoginType:
|
||||||
PASSWORD = "m.login.password"
|
PASSWORD: Final = "m.login.password"
|
||||||
EMAIL_IDENTITY = "m.login.email.identity"
|
EMAIL_IDENTITY: Final = "m.login.email.identity"
|
||||||
MSISDN = "m.login.msisdn"
|
MSISDN: Final = "m.login.msisdn"
|
||||||
RECAPTCHA = "m.login.recaptcha"
|
RECAPTCHA: Final = "m.login.recaptcha"
|
||||||
TERMS = "m.login.terms"
|
TERMS: Final = "m.login.terms"
|
||||||
SSO = "m.login.sso"
|
SSO: Final = "m.login.sso"
|
||||||
DUMMY = "m.login.dummy"
|
DUMMY: Final = "m.login.dummy"
|
||||||
REGISTRATION_TOKEN = "org.matrix.msc3231.login.registration_token"
|
REGISTRATION_TOKEN: Final = "org.matrix.msc3231.login.registration_token"
|
||||||
|
|
||||||
|
|
||||||
# This is used in the `type` parameter for /register when called by
|
# This is used in the `type` parameter for /register when called by
|
||||||
# an appservice to register a new user.
|
# an appservice to register a new user.
|
||||||
APP_SERVICE_REGISTRATION_TYPE = "m.login.application_service"
|
APP_SERVICE_REGISTRATION_TYPE: Final = "m.login.application_service"
|
||||||
|
|
||||||
|
|
||||||
class EventTypes:
|
class EventTypes:
|
||||||
Member = "m.room.member"
|
Member: Final = "m.room.member"
|
||||||
Create = "m.room.create"
|
Create: Final = "m.room.create"
|
||||||
Tombstone = "m.room.tombstone"
|
Tombstone: Final = "m.room.tombstone"
|
||||||
JoinRules = "m.room.join_rules"
|
JoinRules: Final = "m.room.join_rules"
|
||||||
PowerLevels = "m.room.power_levels"
|
PowerLevels: Final = "m.room.power_levels"
|
||||||
Aliases = "m.room.aliases"
|
Aliases: Final = "m.room.aliases"
|
||||||
Redaction = "m.room.redaction"
|
Redaction: Final = "m.room.redaction"
|
||||||
ThirdPartyInvite = "m.room.third_party_invite"
|
ThirdPartyInvite: Final = "m.room.third_party_invite"
|
||||||
RelatedGroups = "m.room.related_groups"
|
RelatedGroups: Final = "m.room.related_groups"
|
||||||
|
|
||||||
RoomHistoryVisibility = "m.room.history_visibility"
|
RoomHistoryVisibility: Final = "m.room.history_visibility"
|
||||||
CanonicalAlias = "m.room.canonical_alias"
|
CanonicalAlias: Final = "m.room.canonical_alias"
|
||||||
Encrypted = "m.room.encrypted"
|
Encrypted: Final = "m.room.encrypted"
|
||||||
RoomAvatar = "m.room.avatar"
|
RoomAvatar: Final = "m.room.avatar"
|
||||||
RoomEncryption = "m.room.encryption"
|
RoomEncryption: Final = "m.room.encryption"
|
||||||
GuestAccess = "m.room.guest_access"
|
GuestAccess: Final = "m.room.guest_access"
|
||||||
|
|
||||||
# These are used for validation
|
# These are used for validation
|
||||||
Message = "m.room.message"
|
Message: Final = "m.room.message"
|
||||||
Topic = "m.room.topic"
|
Topic: Final = "m.room.topic"
|
||||||
Name = "m.room.name"
|
Name: Final = "m.room.name"
|
||||||
|
|
||||||
ServerACL = "m.room.server_acl"
|
ServerACL: Final = "m.room.server_acl"
|
||||||
Pinned = "m.room.pinned_events"
|
Pinned: Final = "m.room.pinned_events"
|
||||||
|
|
||||||
Retention = "m.room.retention"
|
Retention: Final = "m.room.retention"
|
||||||
|
|
||||||
Dummy = "org.matrix.dummy_event"
|
Dummy: Final = "org.matrix.dummy_event"
|
||||||
|
|
||||||
SpaceChild = "m.space.child"
|
SpaceChild: Final = "m.space.child"
|
||||||
SpaceParent = "m.space.parent"
|
SpaceParent: Final = "m.space.parent"
|
||||||
|
|
||||||
MSC2716_INSERTION = "org.matrix.msc2716.insertion"
|
MSC2716_INSERTION: Final = "org.matrix.msc2716.insertion"
|
||||||
MSC2716_BATCH = "org.matrix.msc2716.batch"
|
MSC2716_BATCH: Final = "org.matrix.msc2716.batch"
|
||||||
MSC2716_MARKER = "org.matrix.msc2716.marker"
|
MSC2716_MARKER: Final = "org.matrix.msc2716.marker"
|
||||||
|
|
||||||
|
|
||||||
class ToDeviceEventTypes:
|
class ToDeviceEventTypes:
|
||||||
RoomKeyRequest = "m.room_key_request"
|
RoomKeyRequest: Final = "m.room_key_request"
|
||||||
|
|
||||||
|
|
||||||
class DeviceKeyAlgorithms:
|
class DeviceKeyAlgorithms:
|
||||||
"""Spec'd algorithms for the generation of per-device keys"""
|
"""Spec'd algorithms for the generation of per-device keys"""
|
||||||
|
|
||||||
ED25519 = "ed25519"
|
ED25519: Final = "ed25519"
|
||||||
CURVE25519 = "curve25519"
|
CURVE25519: Final = "curve25519"
|
||||||
SIGNED_CURVE25519 = "signed_curve25519"
|
SIGNED_CURVE25519: Final = "signed_curve25519"
|
||||||
|
|
||||||
|
|
||||||
class EduTypes:
|
class EduTypes:
|
||||||
Presence = "m.presence"
|
Presence: Final = "m.presence"
|
||||||
|
|
||||||
|
|
||||||
class RejectedReason:
|
class RejectedReason:
|
||||||
AUTH_ERROR = "auth_error"
|
AUTH_ERROR: Final = "auth_error"
|
||||||
|
|
||||||
|
|
||||||
class RoomCreationPreset:
|
class RoomCreationPreset:
|
||||||
PRIVATE_CHAT = "private_chat"
|
PRIVATE_CHAT: Final = "private_chat"
|
||||||
PUBLIC_CHAT = "public_chat"
|
PUBLIC_CHAT: Final = "public_chat"
|
||||||
TRUSTED_PRIVATE_CHAT = "trusted_private_chat"
|
TRUSTED_PRIVATE_CHAT: Final = "trusted_private_chat"
|
||||||
|
|
||||||
|
|
||||||
class ThirdPartyEntityKind:
|
class ThirdPartyEntityKind:
|
||||||
USER = "user"
|
USER: Final = "user"
|
||||||
LOCATION = "location"
|
LOCATION: Final = "location"
|
||||||
|
|
||||||
|
|
||||||
ServerNoticeMsgType = "m.server_notice"
|
ServerNoticeMsgType: Final = "m.server_notice"
|
||||||
ServerNoticeLimitReached = "m.server_notice.usage_limit_reached"
|
ServerNoticeLimitReached: Final = "m.server_notice.usage_limit_reached"
|
||||||
|
|
||||||
|
|
||||||
class UserTypes:
|
class UserTypes:
|
||||||
@ -165,91 +167,91 @@ class UserTypes:
|
|||||||
'admin' and 'guest' users should also be UserTypes. Normal users are type None
|
'admin' and 'guest' users should also be UserTypes. Normal users are type None
|
||||||
"""
|
"""
|
||||||
|
|
||||||
SUPPORT = "support"
|
SUPPORT: Final = "support"
|
||||||
BOT = "bot"
|
BOT: Final = "bot"
|
||||||
ALL_USER_TYPES = (SUPPORT, BOT)
|
ALL_USER_TYPES: Final = (SUPPORT, BOT)
|
||||||
|
|
||||||
|
|
||||||
class RelationTypes:
|
class RelationTypes:
|
||||||
"""The types of relations known to this server."""
|
"""The types of relations known to this server."""
|
||||||
|
|
||||||
ANNOTATION = "m.annotation"
|
ANNOTATION: Final = "m.annotation"
|
||||||
REPLACE = "m.replace"
|
REPLACE: Final = "m.replace"
|
||||||
REFERENCE = "m.reference"
|
REFERENCE: Final = "m.reference"
|
||||||
THREAD = "io.element.thread"
|
THREAD: Final = "io.element.thread"
|
||||||
|
|
||||||
|
|
||||||
class LimitBlockingTypes:
|
class LimitBlockingTypes:
|
||||||
"""Reasons that a server may be blocked"""
|
"""Reasons that a server may be blocked"""
|
||||||
|
|
||||||
MONTHLY_ACTIVE_USER = "monthly_active_user"
|
MONTHLY_ACTIVE_USER: Final = "monthly_active_user"
|
||||||
HS_DISABLED = "hs_disabled"
|
HS_DISABLED: Final = "hs_disabled"
|
||||||
|
|
||||||
|
|
||||||
class EventContentFields:
|
class EventContentFields:
|
||||||
"""Fields found in events' content, regardless of type."""
|
"""Fields found in events' content, regardless of type."""
|
||||||
|
|
||||||
# Labels for the event, cf https://github.com/matrix-org/matrix-doc/pull/2326
|
# Labels for the event, cf https://github.com/matrix-org/matrix-doc/pull/2326
|
||||||
LABELS = "org.matrix.labels"
|
LABELS: Final = "org.matrix.labels"
|
||||||
|
|
||||||
# Timestamp to delete the event after
|
# Timestamp to delete the event after
|
||||||
# cf https://github.com/matrix-org/matrix-doc/pull/2228
|
# cf https://github.com/matrix-org/matrix-doc/pull/2228
|
||||||
SELF_DESTRUCT_AFTER = "org.matrix.self_destruct_after"
|
SELF_DESTRUCT_AFTER: Final = "org.matrix.self_destruct_after"
|
||||||
|
|
||||||
# cf https://github.com/matrix-org/matrix-doc/pull/1772
|
# cf https://github.com/matrix-org/matrix-doc/pull/1772
|
||||||
ROOM_TYPE = "type"
|
ROOM_TYPE: Final = "type"
|
||||||
|
|
||||||
# Whether a room can federate.
|
# Whether a room can federate.
|
||||||
FEDERATE = "m.federate"
|
FEDERATE: Final = "m.federate"
|
||||||
|
|
||||||
# The creator of the room, as used in `m.room.create` events.
|
# The creator of the room, as used in `m.room.create` events.
|
||||||
ROOM_CREATOR = "creator"
|
ROOM_CREATOR: Final = "creator"
|
||||||
|
|
||||||
# Used in m.room.guest_access events.
|
# Used in m.room.guest_access events.
|
||||||
GUEST_ACCESS = "guest_access"
|
GUEST_ACCESS: Final = "guest_access"
|
||||||
|
|
||||||
# Used on normal messages to indicate they were historically imported after the fact
|
# Used on normal messages to indicate they were historically imported after the fact
|
||||||
MSC2716_HISTORICAL = "org.matrix.msc2716.historical"
|
MSC2716_HISTORICAL: Final = "org.matrix.msc2716.historical"
|
||||||
# For "insertion" events to indicate what the next batch ID should be in
|
# For "insertion" events to indicate what the next batch ID should be in
|
||||||
# order to connect to it
|
# order to connect to it
|
||||||
MSC2716_NEXT_BATCH_ID = "org.matrix.msc2716.next_batch_id"
|
MSC2716_NEXT_BATCH_ID: Final = "org.matrix.msc2716.next_batch_id"
|
||||||
# Used on "batch" events to indicate which insertion event it connects to
|
# Used on "batch" events to indicate which insertion event it connects to
|
||||||
MSC2716_BATCH_ID = "org.matrix.msc2716.batch_id"
|
MSC2716_BATCH_ID: Final = "org.matrix.msc2716.batch_id"
|
||||||
# For "marker" events
|
# For "marker" events
|
||||||
MSC2716_MARKER_INSERTION = "org.matrix.msc2716.marker.insertion"
|
MSC2716_MARKER_INSERTION: Final = "org.matrix.msc2716.marker.insertion"
|
||||||
|
|
||||||
# The authorising user for joining a restricted room.
|
# The authorising user for joining a restricted room.
|
||||||
AUTHORISING_USER = "join_authorised_via_users_server"
|
AUTHORISING_USER: Final = "join_authorised_via_users_server"
|
||||||
|
|
||||||
|
|
||||||
class RoomTypes:
|
class RoomTypes:
|
||||||
"""Understood values of the room_type field of m.room.create events."""
|
"""Understood values of the room_type field of m.room.create events."""
|
||||||
|
|
||||||
SPACE = "m.space"
|
SPACE: Final = "m.space"
|
||||||
|
|
||||||
|
|
||||||
class RoomEncryptionAlgorithms:
|
class RoomEncryptionAlgorithms:
|
||||||
MEGOLM_V1_AES_SHA2 = "m.megolm.v1.aes-sha2"
|
MEGOLM_V1_AES_SHA2: Final = "m.megolm.v1.aes-sha2"
|
||||||
DEFAULT = MEGOLM_V1_AES_SHA2
|
DEFAULT: Final = MEGOLM_V1_AES_SHA2
|
||||||
|
|
||||||
|
|
||||||
class AccountDataTypes:
|
class AccountDataTypes:
|
||||||
DIRECT = "m.direct"
|
DIRECT: Final = "m.direct"
|
||||||
IGNORED_USER_LIST = "m.ignored_user_list"
|
IGNORED_USER_LIST: Final = "m.ignored_user_list"
|
||||||
|
|
||||||
|
|
||||||
class HistoryVisibility:
|
class HistoryVisibility:
|
||||||
INVITED = "invited"
|
INVITED: Final = "invited"
|
||||||
JOINED = "joined"
|
JOINED: Final = "joined"
|
||||||
SHARED = "shared"
|
SHARED: Final = "shared"
|
||||||
WORLD_READABLE = "world_readable"
|
WORLD_READABLE: Final = "world_readable"
|
||||||
|
|
||||||
|
|
||||||
class GuestAccess:
|
class GuestAccess:
|
||||||
CAN_JOIN = "can_join"
|
CAN_JOIN: Final = "can_join"
|
||||||
# anything that is not "can_join" is considered "forbidden", but for completeness:
|
# anything that is not "can_join" is considered "forbidden", but for completeness:
|
||||||
FORBIDDEN = "forbidden"
|
FORBIDDEN: Final = "forbidden"
|
||||||
|
|
||||||
|
|
||||||
class ReadReceiptEventFields:
|
class ReadReceiptEventFields:
|
||||||
MSC2285_HIDDEN = "org.matrix.msc2285.hidden"
|
MSC2285_HIDDEN: Final = "org.matrix.msc2285.hidden"
|
||||||
|
Loading…
Reference in New Issue
Block a user