Skip to content
Snippets Groups Projects
Select Git revision
  • eee99cdd3fd4a888ca75e7ab41c49a2638de96d7
  • release default protected
  • 11-22-implement-kv-interface-defined-in-collectiveversionedkvgo
  • hotfix/TestHostPool_UpdateNdf_AddFilter
  • XX-4719/announcementChannels
  • xx-4717/logLevel
  • jonah/noob-channel
  • master protected
  • XX-4707/tagDiskJson
  • xx-4698/notification-retry
  • hotfix/notifylockup
  • syncNodes
  • hotfix/localCB
  • XX-4677/NewChanManagerMobile
  • XX-4689/DmSync
  • duplicatePrefix
  • XX-4601/HavenInvites
  • finalizedUICallbacks
  • XX-4673/AdminKeySync
  • debugNotifID
  • anne/test
  • v4.7.5
  • v4.7.4
  • v4.7.3
  • v4.7.2
  • v4.7.1
  • v4.6.3
  • v4.6.1
  • v4.5.0
  • v4.4.4
  • v4.3.11
  • v4.3.8
  • v4.3.7
  • v4.3.6
  • v4.3.5
  • v4.2.0
  • v4.3.0
  • v4.3.4
  • v4.3.3
  • v4.3.2
  • v4.3.1
41 results

gcMessages.pb.go

Blame
  • client.go 1.76 KiB
    ///////////////////////////////////////////////////////////////////////////////
    // Copyright © 2020 xx network SEZC                                          //
    //                                                                           //
    // Use of this source code is governed by a license that can be found in the //
    // LICENSE file                                                              //
    ///////////////////////////////////////////////////////////////////////////////
    
    package connect
    
    import (
    	"github.com/golang/protobuf/proto"
    	"github.com/pkg/errors"
    	"gitlab.com/elixxir/client/e2e/ratchet/partner"
    	"gitlab.com/elixxir/crypto/fastRNG"
    	"gitlab.com/xx_network/crypto/signature/rsa"
    )
    
    // buildClientAuthRequest is a helper function which constructs a marshalled
    // IdentityAuthentication message.
    func buildClientAuthRequest(newPartner partner.Manager,
    	rng *fastRNG.StreamGenerator, rsaPrivKey *rsa.PrivateKey,
    	salt []byte) ([]byte, error) {
    
    	// The connection fingerprint (hashed) will be used as a nonce
    	connectionFp := newPartner.ConnectionFingerprint().Bytes()
    	opts := rsa.NewDefaultOptions()
    	h := opts.Hash.New()
    	h.Write(connectionFp)
    	nonce := h.Sum(nil)
    
    	// Sign the connection fingerprint
    	stream := rng.GetStream()
    	defer stream.Close()
    	signature, err := rsa.Sign(stream, rsaPrivKey,
    		opts.Hash, nonce, opts)
    	if err != nil {
    		return nil, errors.Errorf("failed to sign nonce: %+v", err)
    	}
    
    	// Construct message
    	pemEncodedRsaPubKey := rsa.CreatePublicKeyPem(rsaPrivKey.GetPublic())
    	iar := &IdentityAuthentication{
    		Signature: signature,
    		RsaPubKey: pemEncodedRsaPubKey,
    		Salt:      salt,
    	}
    	payload, err := proto.Marshal(iar)
    	if err != nil {
    		return nil, errors.Errorf("failed to marshal identity request "+
    			"message: %+v", err)
    	}
    
    	return payload, nil
    }