mirror of
https://github.com/twofas/2fas-server.git
synced 2024-11-22 18:30:00 +01:00
90 lines
2.8 KiB
Go
90 lines
2.8 KiB
Go
package tests
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"github.com/twofas/2fas-server/internal/common/crypto"
|
|
"testing"
|
|
)
|
|
|
|
func CreateDevice(t *testing.T, name, fcmToken string) (*DeviceResponse, string) {
|
|
keyPair := crypto.GenerateKeyPair(2048)
|
|
devicePubKey := crypto.PublicKeyToBase64(keyPair.PublicKey)
|
|
|
|
payload := []byte(fmt.Sprintf(`{"name":"%s","platform":"android","fcm_token":"%s"}`, name, fcmToken))
|
|
|
|
device := new(DeviceResponse)
|
|
|
|
DoSuccessPost(t, "mobile/devices", payload, device)
|
|
|
|
return device, devicePubKey
|
|
}
|
|
|
|
func CreateBrowserExtension(t *testing.T, name string) *BrowserExtensionResponse {
|
|
keyPair := crypto.GenerateKeyPair(2048)
|
|
|
|
pubKey := crypto.PublicKeyToBase64(keyPair.PublicKey)
|
|
|
|
payload := []byte(fmt.Sprintf(`{"name":"%s","browser_name":"go-browser","browser_version":"0.1","public_key":"%s"}`, name, pubKey))
|
|
|
|
browserExt := new(BrowserExtensionResponse)
|
|
|
|
DoSuccessPost(t, "/browser_extensions", payload, browserExt)
|
|
|
|
return browserExt
|
|
}
|
|
|
|
func CreateBrowserExtensionWithPublicKey(t *testing.T, name, publicKey string) *BrowserExtensionResponse {
|
|
payload := []byte(fmt.Sprintf(`{"name":"%s","browser_name":"go-browser","browser_version":"0.1","public_key":"%s"}`, name, publicKey))
|
|
|
|
browserExt := new(BrowserExtensionResponse)
|
|
|
|
DoSuccessPost(t, "/browser_extensions", payload, browserExt)
|
|
|
|
return browserExt
|
|
}
|
|
|
|
func PairDeviceWithBrowserExtension(t *testing.T, devicePubKey string, browserExtension *BrowserExtensionResponse, device *DeviceResponse) *PairingResultResponse {
|
|
payload := struct {
|
|
ExtensionId string `json:"extension_id"`
|
|
DeviceName string `json:"device_name"`
|
|
DevicePublicKey string `json:"device_public_key"`
|
|
}{
|
|
ExtensionId: browserExtension.Id,
|
|
DeviceName: device.Name,
|
|
DevicePublicKey: devicePubKey,
|
|
}
|
|
|
|
pairingResult := new(PairingResultResponse)
|
|
|
|
payloadJson, _ := json.Marshal(payload)
|
|
|
|
DoSuccessPost(t, "/mobile/devices/"+device.Id+"/browser_extensions", payloadJson, pairingResult)
|
|
|
|
return pairingResult
|
|
}
|
|
|
|
func GetExtensionDevices(t *testing.T, extensionId string) []*ExtensionPairedDeviceResponse {
|
|
var extensionDevices []*ExtensionPairedDeviceResponse
|
|
|
|
DoSuccessGet(t, "/browser_extensions/"+extensionId+"/devices", &extensionDevices)
|
|
|
|
return extensionDevices
|
|
}
|
|
|
|
func Request2FaToken(t *testing.T, domain, extensionId string) *AuthTokenRequestResponse {
|
|
var response *AuthTokenRequestResponse
|
|
|
|
payload := []byte(fmt.Sprintf(`{"domain":"%s"}`, domain))
|
|
|
|
DoSuccessPost(t, "browser_extensions/"+extensionId+"/commands/request_2fa_token", payload, &response)
|
|
|
|
return response
|
|
}
|
|
|
|
func Send2FaTokenToExtension(t *testing.T, extensionId, deviceId, requestId, token string) {
|
|
j := fmt.Sprintf(`{"token_request_id":"%s","extension_id":"%s","token":"%s"}`, requestId, extensionId, token)
|
|
|
|
DoSuccessPost(t, "mobile/devices/"+deviceId+"/commands/send_2fa_token", []byte(j), nil)
|
|
}
|