| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- package rpc
-
- import (
- "bytes"
- "crypto/rand"
- "encoding/binary"
- "fmt"
- "time"
- )
-
- type NonceRequest struct {
- KeySelector []byte
- CryptoTS []byte
- Nonce []byte
- }
-
- // Bytes returns serialized nonce request.
- func (r *NonceRequest) Bytes() []byte {
- buf := &bytes.Buffer{}
-
- buf.Write(TagNonce)
- buf.Write(r.KeySelector)
- buf.Write(NonceCryptoAES)
- buf.Write(r.CryptoTS)
- buf.Write(r.Nonce)
-
- return buf.Bytes()
- }
-
- // NewNonceRequest builds new none request based on proxy secret.
- func NewNonceRequest(proxySecret []byte) (*NonceRequest, error) {
- nonce := make([]byte, 16) // nolint: gomnd
- keySelector := make([]byte, 4) // nolint: gomnd
- cryptoTS := make([]byte, 4) // nolint: gomnd
-
- if _, err := rand.Read(nonce); err != nil {
- return nil, fmt.Errorf("cannot generate nonce: %w", err)
- }
-
- copy(keySelector, proxySecret)
- // 256 ^ 4 - do not know how to name
- timestamp := time.Now().Truncate(time.Second).Unix() % 4294967296 // nolint: gomnd
- binary.LittleEndian.PutUint32(cryptoTS, uint32(timestamp))
-
- return &NonceRequest{
- KeySelector: keySelector,
- CryptoTS: cryptoTS,
- Nonce: nonce,
- }, nil
- }
|