mirror of
https://github.com/twofas/2fas-server.git
synced 2025-01-07 06:55:49 +01:00
develop/pass fix retry (#43)
fix: pair retry It should be possible to do second pairing right away.
This commit is contained in:
parent
d1176fde8b
commit
1478cc5faf
@ -2,6 +2,7 @@ package connection
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"sync"
|
||||
"time"
|
||||
|
||||
"github.com/gorilla/websocket"
|
||||
@ -52,11 +53,16 @@ func startProxy(wsConn *websocket.Conn, send *safeChannel, read chan []byte) {
|
||||
conn: wsConn,
|
||||
}
|
||||
|
||||
wg := sync.WaitGroup{}
|
||||
wg.Add(2)
|
||||
|
||||
go recovery.DoNotPanic(func() {
|
||||
defer wg.Done()
|
||||
proxy.writePump()
|
||||
})
|
||||
|
||||
go recovery.DoNotPanic(func() {
|
||||
defer wg.Done()
|
||||
proxy.readPump()
|
||||
})
|
||||
|
||||
@ -69,6 +75,8 @@ func startProxy(wsConn *websocket.Conn, send *safeChannel, read chan []byte) {
|
||||
|
||||
proxy.conn.Close()
|
||||
})
|
||||
|
||||
wg.Wait()
|
||||
}
|
||||
|
||||
// readPump pumps messages from the websocket proxy to send.
|
||||
|
@ -33,6 +33,14 @@ func (pp *proxyPool) deleteExpiresPairs() {
|
||||
}
|
||||
}
|
||||
|
||||
func (pp *proxyPool) deleteProxyPair(id string) {
|
||||
pp.mu.Lock()
|
||||
defer pp.mu.Unlock()
|
||||
|
||||
// Channels inside proxyPair are closed in proxy.readPump and proxy.writePump.
|
||||
delete(pp.proxies, id)
|
||||
}
|
||||
|
||||
type proxyPair struct {
|
||||
toMobileDataCh *safeChannel
|
||||
toExtensionDataCh *safeChannel
|
||||
|
@ -40,6 +40,8 @@ func (p *ProxyServer) ServeExtensionProxyToMobileWS(w http.ResponseWriter, r *ht
|
||||
|
||||
proxyPair := p.proxyPool.getOrCreateProxyPair(id)
|
||||
startProxy(conn, proxyPair.toMobileDataCh, proxyPair.toExtensionDataCh.channel)
|
||||
|
||||
p.proxyPool.deleteProxyPair(id)
|
||||
return nil
|
||||
}
|
||||
|
||||
@ -54,5 +56,6 @@ func (p *ProxyServer) ServeMobileProxyToExtensionWS(w http.ResponseWriter, r *ht
|
||||
|
||||
startProxy(conn, proxyPair.toExtensionDataCh, proxyPair.toMobileDataCh.channel)
|
||||
|
||||
p.proxyPool.deleteProxyPair(id)
|
||||
return nil
|
||||
}
|
||||
|
@ -57,12 +57,7 @@ func configureBrowserExtension() (ConfigureBrowserExtensionResponse, error) {
|
||||
}
|
||||
|
||||
// confirmMobile confirms pairing and returns mobile proxy token.
|
||||
func confirmMobile(connectionToken, fcm string) (string, error) {
|
||||
deviceID := uuid.NewString()
|
||||
if deviceIDFromEnv := os.Getenv("TEST_DEVICE_ID"); deviceIDFromEnv != "" {
|
||||
deviceID = deviceIDFromEnv
|
||||
}
|
||||
|
||||
func confirmMobile(connectionToken, deviceID, fcm string) (string, error) {
|
||||
req := struct {
|
||||
DeviceID string `json:"device_id"`
|
||||
FCMToken string `json:"fcm_token"`
|
||||
|
15
tests/pass/lib.go
Normal file
15
tests/pass/lib.go
Normal file
@ -0,0 +1,15 @@
|
||||
package pass
|
||||
|
||||
import (
|
||||
"os"
|
||||
|
||||
"github.com/google/uuid"
|
||||
)
|
||||
|
||||
func getDeviceID() string {
|
||||
deviceID := uuid.NewString()
|
||||
if deviceIDFromEnv := os.Getenv("TEST_DEVICE_ID"); deviceIDFromEnv != "" {
|
||||
deviceID = deviceIDFromEnv
|
||||
}
|
||||
return deviceID
|
||||
}
|
@ -22,6 +22,28 @@ func TestPairHappyFlow(t *testing.T) {
|
||||
t.Fatalf("Failed to configure browser extension: %v", err)
|
||||
}
|
||||
|
||||
deviceID := getDeviceID()
|
||||
testPairing(t, deviceID, resp)
|
||||
}
|
||||
|
||||
func TestPairMultipleTimes(t *testing.T) {
|
||||
resp, err := configureBrowserExtension()
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to configure browser extension: %v", err)
|
||||
}
|
||||
|
||||
deviceID := getDeviceID()
|
||||
for i := 0; i < 10; i++ {
|
||||
testPairing(t, deviceID, resp)
|
||||
if t.Failed() {
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func testPairing(t *testing.T, deviceID string, resp ConfigureBrowserExtensionResponse) {
|
||||
t.Helper()
|
||||
|
||||
browserExtensionDone := make(chan struct{})
|
||||
mobileDone := make(chan struct{})
|
||||
|
||||
@ -51,7 +73,7 @@ func TestPairHappyFlow(t *testing.T) {
|
||||
go func() {
|
||||
defer close(mobileDone)
|
||||
|
||||
mobileProxyToken, err := confirmMobile(resp.ConnectionToken, uuid.NewString())
|
||||
mobileProxyToken, err := confirmMobile(resp.ConnectionToken, deviceID, uuid.NewString())
|
||||
if err != nil {
|
||||
t.Errorf("Mobile: confirm failed: %v", err)
|
||||
return
|
||||
|
@ -16,6 +16,7 @@ func TestSyncHappyFlow(t *testing.T) {
|
||||
mobileParingDone := make(chan struct{})
|
||||
|
||||
fcm := uuid.NewString()
|
||||
deviceID := getDeviceID()
|
||||
|
||||
go func() {
|
||||
defer close(browserExtensionDone)
|
||||
@ -44,7 +45,7 @@ func TestSyncHappyFlow(t *testing.T) {
|
||||
go func() {
|
||||
defer close(mobileParingDone)
|
||||
|
||||
_, err := confirmMobile(resp.ConnectionToken, fcm)
|
||||
_, err := confirmMobile(resp.ConnectionToken, deviceID, fcm)
|
||||
if err != nil {
|
||||
t.Errorf("Mobile: confirm failed: %v", err)
|
||||
return
|
||||
|
Loading…
Reference in New Issue
Block a user