watchtower/wtclient/interface+wtmock: add session key reservation

This commit is contained in:
Conner Fromknecht 2019-04-23 20:04:40 -07:00
parent df390df966
commit 0404aedede
No known key found for this signature in database
GPG Key ID: E7D737B67FA592C7
2 changed files with 33 additions and 0 deletions

@ -23,6 +23,14 @@ type DB interface {
// LoadTower retrieves a tower by its tower ID. // LoadTower retrieves a tower by its tower ID.
LoadTower(uint64) (*wtdb.Tower, error) LoadTower(uint64) (*wtdb.Tower, error)
// NextSessionKeyIndex reserves a new session key derivation index for a
// particular tower id. The index is reserved for that tower until
// CreateClientSession is invoked for that tower and index, at which
// point a new index for that tower can be reserved. Multiple calls to
// this method before CreateClientSession is invoked should return the
// same index.
NextSessionKeyIndex(uint64) (uint32, error)
// CreateClientSession saves a newly negotiated client session to the // CreateClientSession saves a newly negotiated client session to the
// client's database. This enables the session to be used across // client's database. This enables the session to be used across
// restarts. // restarts.

@ -22,6 +22,9 @@ type ClientDB struct {
activeSessions map[wtdb.SessionID]*wtdb.ClientSession activeSessions map[wtdb.SessionID]*wtdb.ClientSession
towerIndex map[towerPK]uint64 towerIndex map[towerPK]uint64
towers map[uint64]*wtdb.Tower towers map[uint64]*wtdb.Tower
nextIndex uint32
indexes map[uint64]uint32
} }
// NewClientDB initializes a new mock ClientDB. // NewClientDB initializes a new mock ClientDB.
@ -31,6 +34,7 @@ func NewClientDB() *ClientDB {
activeSessions: make(map[wtdb.SessionID]*wtdb.ClientSession), activeSessions: make(map[wtdb.SessionID]*wtdb.ClientSession),
towerIndex: make(map[towerPK]uint64), towerIndex: make(map[towerPK]uint64),
towers: make(map[uint64]*wtdb.Tower), towers: make(map[uint64]*wtdb.Tower),
indexes: make(map[uint64]uint32),
} }
} }
@ -118,6 +122,27 @@ func (m *ClientDB) CreateClientSession(session *wtdb.ClientSession) error {
return nil return nil
} }
// NextSessionKeyIndex reserves a new session key derivation index for a
// particular tower id. The index is reserved for that tower until
// CreateClientSession is invoked for that tower and index, at which point a new
// index for that tower can be reserved. Multiple calls to this method before
// CreateClientSession is invoked should return the same index.
func (m *ClientDB) NextSessionKeyIndex(towerID uint64) (uint32, error) {
m.mu.Lock()
defer m.mu.Unlock()
if index, ok := m.indexes[towerID]; ok {
return index, nil
}
index := m.nextIndex
m.indexes[towerID] = index
m.nextIndex++
return index, nil
}
// CommitUpdate persists the CommittedUpdate provided in the slot for (session, // CommitUpdate persists the CommittedUpdate provided in the slot for (session,
// seqNum). This allows the client to retransmit this update on startup. // seqNum). This allows the client to retransmit this update on startup.
func (m *ClientDB) CommitUpdate(id *wtdb.SessionID, seqNum uint16, func (m *ClientDB) CommitUpdate(id *wtdb.SessionID, seqNum uint16,