* rfc: member keys * update plan * new encoding for message batches * send new batch encoding in relay-based groups * mvp launch plan * update plan * core: verify group member keys (#6669) * core: verify group member keys * refactor, process forwards * refactor parsing * refactor parsing 2 * refactor parser 3 * update rfc * simplify * simplify * log tag * refactor tag logging * refactor withVerifiedSig * simplify * refactor more * comment * fix encoding * fix sending as group for the new binary batch encoding * unify types * update api docs * clean up --------- Co-authored-by: Evgeny @ SimpleX Chat <259188159+evgeny-simplex@users.noreply.github.com> * core: signing messages with member keys (#6675) * core: signing messages with member keys (types) * sign messages * refactor batching * better * refactor * remove unused Eq --------- Co-authored-by: Evgeny @ SimpleX Chat <259188159+evgeny-simplex@users.noreply.github.com> * core: forward signed messages as unchanged binary strings (#6678) * core: forward signed messages as unchanged binary strings * refactor * consolidate types * refactor VerifiedMsg * refactor more * undo rename Co-authored-by: Evgeny <evgeny@poberezkin.com> * update schema and plans * add signed status to chat items and events * test signed chat items * unify parser * PostgreSQL fix, remove unused fields, option to send inline files in the tests * change inline files config * revert inline config change * use different characters in batch encoding, to avoid conflict with inline files * fix test, api docs, query plans --------- Co-authored-by: Evgeny @ SimpleX Chat <259188159+evgeny-simplex@users.noreply.github.com> --------- Co-authored-by: spaced4ndy <8711996+spaced4ndy@users.noreply.github.com> Co-authored-by: Evgeny @ SimpleX Chat <259188159+evgeny-simplex@users.noreply.github.com>
17 KiB
API Events
This file is generated automatically.
- Main event
- Other events
- Main event
- Other events
- Main events
- Other events
- Main events
- Other events
- AcceptingContactRequest
- AcceptingBusinessRequest
- ContactConnecting
- BusinessLinkConnecting
- JoinedGroupMemberConnecting
- SentGroupInvitation
- GroupLinkConnecting
Contact connection events
Bots must use these events to process connecting users.
Most bots enable auto-accept and don't need to accept connections via commands.
You may create bot SimpleX address manually via CLI or desktop app or from bot code with these commands:
- APIShowMyAddress to check if address exists,
- APICreateMyAddress to create address,
- APISetAddressSettings to enable auto-access.
ContactConnected
This event is sent after a user connects via bot SimpleX address (not a business address).
Record type:
ContactUpdated
Contact profile of another user is updated.
Record type:
ContactDeletedByContact
Bot user's connection with another contact is deleted (conversation is kept).
Record type:
ReceivedContactRequest
Contact request received.
This event is only sent when auto-accept is disabled.
The request needs to be accepted using APIAcceptContact command
Record type:
- type: "receivedContactRequest"
- user: User
- contactRequest: UserContactRequest
- chat_: AChat?
NewMemberContactReceivedInv
Received invitation to connect directly with a group member.
This event only needs to be processed to associate contact with group, the connection will proceed automatically.
Record type:
- type: "newMemberContactReceivedInv"
- user: User
- contact: Contact
- groupInfo: GroupInfo
- member: GroupMember
ContactSndReady
Connecting via 1-time invitation or after accepting contact request.
After this event bot can send messages to this contact.
Record type:
Message events
Bots must use these events to process received messages.
NewChatItems
Received message(s).
Record type:
ChatItemReaction
Received message reaction.
Record type:
- type: "chatItemReaction"
- user: User
- added: bool
- reaction: ACIReaction
ChatItemsDeleted
Message was deleted by another user.
Record type:
- type: "chatItemsDeleted"
- user: User
- chatItemDeletions: [ChatItemDeletion]
- byUser: bool
- timed: bool
ChatItemUpdated
Message was updated by another user.
Record type:
GroupChatItemsDeleted
Group messages are deleted or moderated.
Record type:
- type: "groupChatItemsDeleted"
- user: User
- groupInfo: GroupInfo
- chatItemIDs: [int64]
- byUser: bool
- member_: GroupMember?
ChatItemsStatusesUpdated
Message delivery status updates.
Record type:
Group events
Bots may use these events to manage users' groups and business address groups.
Please note: programming groups is more complex than programming direct connections
ReceivedGroupInvitation
Received group invitation.
Record type:
- type: "receivedGroupInvitation"
- user: User
- groupInfo: GroupInfo
- contact: Contact
- fromMemberRole: GroupMemberRole
- memberRole: GroupMemberRole
UserJoinedGroup
Bot user joined group. Received when connection via group link completes.
Record type:
- type: "userJoinedGroup"
- user: User
- groupInfo: GroupInfo
- hostMember: GroupMember
GroupUpdated
Group profile or preferences updated.
Record type:
- type: "groupUpdated"
- user: User
- fromGroup: GroupInfo
- toGroup: GroupInfo
- member_: GroupMember?
- msgSigned: bool
JoinedGroupMember
Another member joined group.
Record type:
- type: "joinedGroupMember"
- user: User
- groupInfo: GroupInfo
- member: GroupMember
MemberRole
Member (or bot user's) group role changed.
Record type:
- type: "memberRole"
- user: User
- groupInfo: GroupInfo
- byMember: GroupMember
- member: GroupMember
- fromRole: GroupMemberRole
- toRole: GroupMemberRole
- msgSigned: bool
DeletedMember
Another member is removed from the group.
Record type:
- type: "deletedMember"
- user: User
- groupInfo: GroupInfo
- byMember: GroupMember
- deletedMember: GroupMember
- withMessages: bool
- msgSigned: bool
LeftMember
Another member left the group.
Record type:
- type: "leftMember"
- user: User
- groupInfo: GroupInfo
- member: GroupMember
DeletedMemberUser
Bot user was removed from the group.
Record type:
- type: "deletedMemberUser"
- user: User
- groupInfo: GroupInfo
- member: GroupMember
- withMessages: bool
- msgSigned: bool
GroupDeleted
Group was deleted by the owner (not bot user).
Record type:
- type: "groupDeleted"
- user: User
- groupInfo: GroupInfo
- member: GroupMember
- msgSigned: bool
ConnectedToGroupMember
Connected to another group member.
Record type:
- type: "connectedToGroupMember"
- user: User
- groupInfo: GroupInfo
- member: GroupMember
- memberContact: Contact?
MemberAcceptedByOther
Another group owner, admin or moderator accepted member to the group after review ("knocking").
Record type:
- type: "memberAcceptedByOther"
- user: User
- groupInfo: GroupInfo
- acceptingMember: GroupMember
- member: GroupMember
MemberBlockedForAll
Another member blocked for all members.
Record type:
- type: "memberBlockedForAll"
- user: User
- groupInfo: GroupInfo
- byMember: GroupMember
- member: GroupMember
- blocked: bool
- msgSigned: bool
GroupMemberUpdated
Another group member profile updated.
Record type:
- type: "groupMemberUpdated"
- user: User
- groupInfo: GroupInfo
- fromMember: GroupMember
- toMember: GroupMember
GroupLinkRelaysUpdated
Group link relays updated.
Record type:
- type: "groupLinkRelaysUpdated"
- user: User
- groupInfo: GroupInfo
- groupLink: GroupLink
- groupRelays: [GroupRelay]
File events
Bots that send or receive files may process these events to track delivery status and to process completion.
Bots that need to receive or moderate files (e.g., based on name, size or extension), can use relevant commands (e.g., ReceiveFile or APIDeleteMemberChatItem) when processing NewChatItems event.
Bots that need to send files should use APISendMessages command.
RcvFileDescrReady
File is ready to be received.
This event is useful for processing sender file servers and monitoring file reception progress.
ReceiveFile command can be used before this event.
Record type:
- type: "rcvFileDescrReady"
- user: User
- chatItem: AChatItem
- rcvFileTransfer: RcvFileTransfer
- rcvFileDescr: RcvFileDescr
RcvFileComplete
File reception is competed.
Record type:
SndFileCompleteXFTP
File upload is competed.
Record type:
- type: "sndFileCompleteXFTP"
- user: User
- chatItem: AChatItem
- fileTransferMeta: FileTransferMeta
RcvFileStart
File reception started. This event will be sent after CEvtRcvFileDescrReady event.
Record type:
RcvFileSndCancelled
File was cancelled by the sender. This event may be sent instead of CEvtRcvFileDescrReady event.
Record type:
- type: "rcvFileSndCancelled"
- user: User
- chatItem: AChatItem
- rcvFileTransfer: RcvFileTransfer
RcvFileAccepted
This event will be sent when file is automatically accepted because of CLI option.
Record type:
RcvFileError
Error receiving file.
Record type:
- type: "rcvFileError"
- user: User
- chatItem_: AChatItem?
- agentError: AgentErrorType
- rcvFileTransfer: RcvFileTransfer
RcvFileWarning
Warning when receiving file. It can happen when CLI settings do not allow to connect to file server(s).
Record type:
- type: "rcvFileWarning"
- user: User
- chatItem_: AChatItem?
- agentError: AgentErrorType
- rcvFileTransfer: RcvFileTransfer
SndFileError
Error sending file.
Record type:
- type: "sndFileError"
- user: User
- chatItem_: AChatItem?
- fileTransferMeta: FileTransferMeta
- errorMessage: string
SndFileWarning
Warning when sending file.
Record type:
- type: "sndFileWarning"
- user: User
- chatItem_: AChatItem?
- fileTransferMeta: FileTransferMeta
- errorMessage: string
Connection progress events
Bots may use these events to track progress of connections for monitoring or debugging.
AcceptingContactRequest
Automatically accepting contact request via bot's SimpleX address with auto-accept enabled.
Record type:
AcceptingBusinessRequest
Automatically accepting contact request via bot's business address.
Record type:
ContactConnecting
Contact confirmed connection.
Sent when contact started connecting via bot's 1-time invitation link or when bot connects to another SimpleX address.
Record type:
BusinessLinkConnecting
Contact confirmed connection.
Sent when bot connects to another business address.
Record type:
- type: "businessLinkConnecting"
- user: User
- groupInfo: GroupInfo
- hostMember: GroupMember
- fromContact: Contact
JoinedGroupMemberConnecting
Group member is announced to the group and will be connecting to bot.
Record type:
- type: "joinedGroupMemberConnecting"
- user: User
- groupInfo: GroupInfo
- hostMember: GroupMember
- member: GroupMember
SentGroupInvitation
Sent when another user joins group via bot's link.
Record type:
- type: "sentGroupInvitation"
- user: User
- groupInfo: GroupInfo
- contact: Contact
- member: GroupMember
GroupLinkConnecting
Sent when bot joins group via another user link.
Record type:
- type: "groupLinkConnecting"
- user: User
- groupInfo: GroupInfo
- hostMember: GroupMember
Network connection events
HostConnected
Messaging or file server connected
Record type:
- type: "hostConnected"
- protocol: string
- transportHost: string
HostDisconnected
Messaging or file server disconnected
Record type:
- type: "hostDisconnected"
- protocol: string
- transportHost: string
SubscriptionStatus
Messaging subscription status changed
Record type:
- type: "subscriptionStatus"
- server: string
- subscriptionStatus: SubscriptionStatus
- connections: [string]
Error events
Bots may log these events for debugging. There will be many error events - this does NOT indicate a malfunction - e.g., they may happen because of bad network connectivity, or because messages may be delivered to deleted chats for a short period of time (they will be ignored).
MessageError
Message error.
Record type:
- type: "messageError"
- user: User
- severity: string
- errorMessage: string
ChatError
Chat error (only used in WebSockets API).
Record type:
- type: "chatError"
- chatError: ChatError
ChatErrors
Chat errors.
Record type:
- type: "chatErrors"
- chatErrors: [ChatError]