session

package
v0.1.0 Latest Latest
Warning

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

Go to latest
Published: Jul 23, 2020 License: BSD-3-Clause Imports: 4 Imported by: 8

Documentation

Overview

Package session defines session states and session stores in Mute.

Index

Constants

This section is empty.

Variables

View Source
var ErrMessageKeyUsed = errors.New("msg: message key has already been used")

ErrMessageKeyUsed is raised when a message key has already been used.

View Source
var ErrNoKeyEntry = errors.New("msg: no KeyEntry found")

ErrNoKeyEntry is raised when no KeyEntry message could be found.

Functions

func CalcKey

func CalcKey(
	senderIdentityHash string,
	recipientIdentityHash string,
	senderSessionHash string,
	recipientSessionHash string,
) string

CalcKey computes the session key from senderIdentityHash, recipientIdentityHash, senderSessionHash, and recipientSessionHash.

func CalcStateKey

func CalcStateKey(senderIdentityPub, recipientIdentityPub *[32]byte) string

CalcStateKey computes the session state key from senderIdentityPub and recipientIdentityPub.

func StateEqual

func StateEqual(a, b *State) bool

StateEqual returns a boolean reporting whether a and b have the same exported fields.

Types

type State

type State struct {
	SenderSessionCount          uint64        // total number of messages sent in sessions before this SenderSessionPub was used
	SenderMessageCount          uint64        // total number of messages sent with this SenderSessionPub
	MaxRecipientCount           uint64        // the highest SenderMessageCount from recipient (for message key timeouts)
	RecipientTemp               uid.KeyEntry  // RecipientKeyInitPub or RecipientSessionPub
	SenderSessionPub            uid.KeyEntry  // public session key from sender
	NextSenderSessionPub        *uid.KeyEntry // new SenderSessionPub to refresh the session
	NextRecipientSessionPubSeen *uid.KeyEntry // currently known NextSenderSessionPub of the other party
	NymAddress                  string        // current NymAddress from recipient
	KeyInitSession              bool          // this session was started with a KeyInit message
}

State describes the current session state between two communicating parties.

type Store

type Store interface {
	// GetSessionState returns the current session state or nil, if no state
	// exists between the two parties.
	GetSessionState(sessionStateKey string) (*State, error)
	// SetSesssionState sets the current session state between two parties.
	SetSessionState(sessionStateKey string, sessionState *State) error
	// StoreSession stores a new session.
	// rootKeyHash is the base64 encoded root key hash.
	// chainKey is the base64 encoded chain key.
	// send and recv are arrays containing NumOfFutureKeys many base64 encoded
	// future keys.
	StoreSession(sessionKey, rootKeyHash, chainKey string,
		send, recv []string) error
	// HasSession returns a boolean reporting whether a session exists.
	HasSession(sessionKey string) bool
	// GetPublicKeyInit returns the private KeyEntry contained in the KeyInit
	// message with the given pubKeyHash.
	// If no such KeyEntry is available, ErrNoKeyEntry is returned.
	GetPrivateKeyEntry(pubKeyHash string) (*uid.KeyEntry, error)
	// GetPrivateKeyInit returns a public KeyEntry and NYMADDRESS contained in
	// the KeyInit message for the given uidMsg.
	// If no such KeyEntry is available, ErrNoKeyEntry is returned.
	GetPublicKeyEntry(uidMsg *uid.Message) (*uid.KeyEntry, string, error)
	// GetMessageKey returns the message key with index msgIndex. If sender is
	// true the sender key is returned, otherwise the recipient key.
	GetMessageKey(sessionKey string, sender bool,
		msgIndex uint64) (*[64]byte, error)
	// NumMessageKeys returns the number of precomputed messages keys.
	NumMessageKeys(sessionKey string) (uint64, error)
	// GetRootKeyHash returns the root key hash for the session.
	GetRootKeyHash(sessionKey string) (*[64]byte, error)
	// GetChainKey returns the chain key for the session.
	GetChainKey(sessionKey string) (*[32]byte, error)
	// DelMessageKey deleted the message key with index msgIndex. If sender is
	// true the sender key is deleted, otherwise the recipient key.
	DelMessageKey(sessionKey string, sender bool, msgIndex uint64) error

	// AddSessionKey adds a session key.
	AddSessionKey(hash, json, privKey string, cleanupTime uint64) error
	// GetSessionKey returns a session key.
	// If no such session key is available, ErrNoKeyEntry is returned.
	GetSessionKey(hash string) (json, privKey string, err error)
	// DelPrivSessionKey deletes the private key of a session key.
	// It should not fail if no public key for the hash exists or if the
	// private key has already been deleted.
	DelPrivSessionKey(hash string) error
	// CleanupSessionKeys deletes all session keys with a cleanup time before t.
	CleanupSessionKeys(t uint64) error
}

The Store interface defines all methods for managing session keys.

Directories

Path Synopsis
Package memstore implements a key store in memory (for testing purposes).
Package memstore implements a key store in memory (for testing purposes).

Jump to

Keyboard shortcuts

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