mautrix-signal/pkg/libsignalgo/messagebackupkey.go

104 lines
3.0 KiB
Go

// mautrix-signal - A Matrix-signal puppeting bridge.
// Copyright (C) 2025 Tulir Asokan
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
package libsignalgo
/*
#include "./libsignal-ffi.h"
*/
import "C"
import (
"runtime"
"unsafe"
)
type MessageBackupKey struct {
nc noCopy
ptr *C.SignalMessageBackupKey
}
func wrapMessageBackupKey(ptr *C.SignalMessageBackupKey) *MessageBackupKey {
backupKey := &MessageBackupKey{ptr: ptr}
runtime.SetFinalizer(backupKey, (*MessageBackupKey).Destroy)
return backupKey
}
func MessageBackupKeyFromAccountEntropyPool(aep AccountEntropyPool, aci ServiceID) (*MessageBackupKey, error) {
var bk C.SignalMutPointerMessageBackupKey
signalFfiError := C.signal_message_backup_key_from_account_entropy_pool(
&bk,
C.CString(string(aep)),
aci.CFixedBytes(),
)
runtime.KeepAlive(aep)
if signalFfiError != nil {
return nil, wrapError(signalFfiError)
}
return wrapMessageBackupKey(bk.raw), nil
}
func MessageBackupKeyFromBackupKeyAndID(backupKey *BackupKey, backupID *BackupID) (*MessageBackupKey, error) {
var bk C.SignalMutPointerMessageBackupKey
signalFfiError := C.signal_message_backup_key_from_backup_key_and_backup_id(
&bk,
(*[C.SignalBACKUP_KEY_LEN]C.uint8_t)(unsafe.Pointer(backupKey)),
(*[BackupIDLength]C.uint8_t)(unsafe.Pointer(backupID)),
)
runtime.KeepAlive(backupKey)
runtime.KeepAlive(backupID)
if signalFfiError != nil {
return nil, wrapError(signalFfiError)
}
return wrapMessageBackupKey(bk.raw), nil
}
func (bk *MessageBackupKey) mutPtr() C.SignalMutPointerMessageBackupKey {
return C.SignalMutPointerMessageBackupKey{bk.ptr}
}
func (bk *MessageBackupKey) constPtr() C.SignalConstPointerMessageBackupKey {
return C.SignalConstPointerMessageBackupKey{bk.ptr}
}
func (bk *MessageBackupKey) Destroy() error {
runtime.SetFinalizer(bk, nil)
return wrapError(C.signal_message_backup_key_destroy(bk.mutPtr()))
}
func (bk *MessageBackupKey) GetHMACKey() ([32]byte, error) {
var out [32]byte
signalFfiError := C.signal_message_backup_key_get_hmac_key(
(*[32]C.uint8_t)(unsafe.Pointer(&out)),
bk.constPtr(),
)
if signalFfiError != nil {
return out, wrapError(signalFfiError)
}
return out, nil
}
func (bk *MessageBackupKey) GetAESKey() ([32]byte, error) {
var out [32]byte
signalFfiError := C.signal_message_backup_key_get_aes_key(
(*[32]C.uint8_t)(unsafe.Pointer(&out)),
bk.constPtr(),
)
if signalFfiError != nil {
return out, wrapError(signalFfiError)
}
return out, nil
}