verificationhelper

package
v0.19.0-mod-2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 31, 2024 License: MPL-2.0 Imports: 26 Imported by: 0

Documentation

Overview

Package verificationhelper provides a helper for the interactive verification process according to Section 11.12.2 of the Spec.

Index

Constants

This section is empty.

Variables

View Source
var (
	ErrInvalidQRCodeHeader  = errors.New("invalid QR code header")
	ErrUnknownQRCodeVersion = errors.New("invalid QR code version")
	ErrInvalidQRCodeMode    = errors.New("invalid QR code mode")
)

Functions

func BrokenB64Encode deprecated

func BrokenB64Encode(input []byte) string

BrokenB64Encode implements the incorrect base64 serialization in libolm for the hkdf-hmac-sha256 MAC method. The bug is caused by the input and output buffers being equal to one another during the base64 encoding.

This function is narrowly scoped to this specific bug, and does not work generally (it only supports if the input is 32-bytes).

See https://github.com/matrix-org/matrix-spec-proposals/pull/3783 and https://gitlab.matrix.org/matrix-org/olm/-/merge_requests/16 for details.

Deprecated: never use this. It is only here for compatibility with the broken libolm implementation.

Types

type QRCode

type QRCode struct {
	Mode          QRCodeMode
	TransactionID id.VerificationTransactionID
	Key1, Key2    [32]byte
	SharedSecret  []byte
}

func NewQRCode

func NewQRCode(mode QRCodeMode, txnID id.VerificationTransactionID, key1, key2 [32]byte) *QRCode

func NewQRCodeFromBytes

func NewQRCodeFromBytes(data []byte) (*QRCode, error)

NewQRCodeFromBytes parses the bytes from a QR code scan as defined in Section 11.12.2.4.1 of the Spec.

func (*QRCode) Bytes

func (q *QRCode) Bytes() []byte

Bytes returns the bytes that need to be encoded in the QR code as defined in Section 11.12.2.4.1 of the Spec.

type QRCodeMode

type QRCodeMode byte
const (
	QRCodeModeCrossSigning                    QRCodeMode = 0x00
	QRCodeModeSelfVerifyingMasterKeyTrusted   QRCodeMode = 0x01
	QRCodeModeSelfVerifyingMasterKeyUntrusted QRCodeMode = 0x02
)

type RequiredCallbacks

type RequiredCallbacks interface {
	// VerificationRequested is called when a verification request is received
	// from another device.
	VerificationRequested(ctx context.Context, txnID id.VerificationTransactionID, from id.UserID)

	// VerificationCancelled is called when the verification is cancelled.
	VerificationCancelled(ctx context.Context, txnID id.VerificationTransactionID, code event.VerificationCancelCode, reason string)

	// VerificationDone is called when the verification is done.
	VerificationDone(ctx context.Context, txnID id.VerificationTransactionID)
}

RequiredCallbacks is an interface representing the callbacks required for the VerificationHelper.

type ShowQRCodeCallbacks

type ShowQRCodeCallbacks interface {
	// ScanQRCode is called when another device has sent a
	// m.key.verification.ready event and indicated that they are capable of
	// showing a QR code.
	ScanQRCode(ctx context.Context, txnID id.VerificationTransactionID)

	// ShowQRCode is called when the verification has been accepted and a QR
	// code should be shown to the user.
	ShowQRCode(ctx context.Context, txnID id.VerificationTransactionID, qrCode *QRCode)

	// QRCodeScanned is called when the other user has scanned the QR code and
	// sent the m.key.verification.start event.
	QRCodeScanned(ctx context.Context, txnID id.VerificationTransactionID)
}

type ShowSASCallbacks

type ShowSASCallbacks interface {
	// ShowSAS is a callback that is called when the SAS verification has
	// generated a short authentication string to show. It is guaranteed that
	// either the emojis list, or the decimals list, or both will be present.
	ShowSAS(ctx context.Context, txnID id.VerificationTransactionID, emojis []rune, decimals []int)
}

type VerificationHelper

type VerificationHelper struct {
	// contains filtered or unexported fields
}

func NewVerificationHelper

func NewVerificationHelper(client *mautrix.Client, mach *crypto.OlmMachine, callbacks any, supportsScan bool) *VerificationHelper

func (*VerificationHelper) AcceptVerification

func (vh *VerificationHelper) AcceptVerification(ctx context.Context, txnID id.VerificationTransactionID) error

AcceptVerification accepts a verification request. The transaction ID should be the transaction ID of a verification request that was received via the VerificationRequested callback in RequiredCallbacks.

func (*VerificationHelper) CancelVerification

func (vh *VerificationHelper) CancelVerification(ctx context.Context, txnID id.VerificationTransactionID, code event.VerificationCancelCode, reason string) error

CancelVerification cancels a verification request. The transaction ID should be the transaction ID of a verification request that was received via the VerificationRequested callback in RequiredCallbacks.

func (*VerificationHelper) ConfirmQRCodeScanned

func (vh *VerificationHelper) ConfirmQRCodeScanned(ctx context.Context, txnID id.VerificationTransactionID) error

ConfirmQRCodeScanned confirms that our QR code has been scanned and sends the m.key.verification.done event to the other device.

func (*VerificationHelper) ConfirmSAS

ConfirmSAS indicates that the user has confirmed that the SAS matches SAS shown on the other user's device.

func (*VerificationHelper) HandleScannedQRData

func (vh *VerificationHelper) HandleScannedQRData(ctx context.Context, data []byte) error

HandleScannedQRData verifies the keys from a scanned QR code and if successful, sends the m.key.verification.start event and m.key.verification.done event.

func (*VerificationHelper) Init

func (vh *VerificationHelper) Init(ctx context.Context) error

Init initializes the verification helper by adding the necessary event handlers to the syncer.

func (*VerificationHelper) StartInRoomVerification

func (vh *VerificationHelper) StartInRoomVerification(ctx context.Context, roomID id.RoomID, to id.UserID) (id.VerificationTransactionID, error)

StartInRoomVerification starts an interactive verification flow with the given user in the given room.

func (*VerificationHelper) StartSAS

StartSAS starts a SAS verification flow. The transaction ID should be the transaction ID of a verification request that was received via the VerificationRequested callback in RequiredCallbacks.

func (*VerificationHelper) StartVerification

func (vh *VerificationHelper) StartVerification(ctx context.Context, to id.UserID) (id.VerificationTransactionID, error)

StartVerification starts an interactive verification flow with the given user via a to-device event.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL