Skip to content
Snippets Groups Projects
Select Git revision
  • 6a540463535f8f38523e61ad5f9e6e2345921514
  • main default protected
  • development
  • integration
  • v1.1.5
  • v1.1.4
  • v1.1.3
  • v1.1.2
  • v1.1.1
  • v1.1.0
  • v1.0.0
11 results

CmixConnect.swift

Blame
  • send.go 3.03 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 network
    
    import (
    	"github.com/pkg/errors"
    	jww "github.com/spf13/jwalterweatherman"
    	"gitlab.com/elixxir/client/interfaces/message"
    	"gitlab.com/elixxir/client/interfaces/params"
    	"gitlab.com/elixxir/client/stoppable"
    	"gitlab.com/elixxir/crypto/e2e"
    	"gitlab.com/elixxir/primitives/format"
    	"gitlab.com/xx_network/primitives/id"
    	"gitlab.com/xx_network/primitives/id/ephemeral"
    	"time"
    )
    
    // SendCMIX sends a "raw" CMIX message payload to the provided
    // recipient. Note that both SendE2E and SendUnsafe call SendCMIX.
    // Returns the round ID of the round the payload was sent or an error
    // if it fails.
    func (m *manager) SendCMIX(msg format.Message, recipient *id.ID, param params.CMIX) (id.Round, ephemeral.Id, error) {
    	if !m.Health.IsHealthy() {
    		return 0, ephemeral.Id{}, errors.New("Cannot send cmix message when the " +
    			"network is not healthy")
    	}
    
    	return m.message.SendCMIX(m.GetSender(), msg, recipient, param, nil)
    }
    
    // SendManyCMIX sends many "raw" CMIX message payloads to each of the
    // provided recipients. Used for group chat functionality. Returns the
    // round ID of the round the payload was sent or an error if it fails.
    func (m *manager) SendManyCMIX(msgs []message.TargetedCmixMessage,
    	p params.CMIX) (id.Round, []ephemeral.Id, error) {
    
    	return m.message.SendManyCMIX(m.sender, msgs, p, nil)
    }
    
    // SendUnsafe sends an unencrypted payload to the provided recipient
    // with the provided msgType. Returns the list of rounds in which parts
    // of the message were sent or an error if it fails.
    // NOTE: Do not use this function unless you know what you are doing.
    // This function always produces an error message in client logging.
    func (m *manager) SendUnsafe(msg message.Send, param params.Unsafe) ([]id.Round, error) {
    	if !m.Health.IsHealthy() {
    		return nil, errors.New("cannot send unsafe message when the " +
    			"network is not healthy")
    	}
    
    	jww.WARN.Println("Sending unsafe message. Unsafe payloads have no end" +
    		" to end encryption, they have limited security and privacy " +
    		"preserving properties")
    
    	return m.message.SendUnsafe(msg, param)
    }
    
    // SendE2E sends an end-to-end payload to the provided recipient with
    // the provided msgType. Returns the list of rounds in which parts of
    // the message were sent or an error if it fails.
    func (m *manager) SendE2E(msg message.Send, e2eP params.E2E, stop *stoppable.Single) (
    	[]id.Round, e2e.MessageID, time.Time, error) {
    
    	if !m.Health.IsHealthy() {
    		return nil, e2e.MessageID{}, time.Time{}, errors.New("Cannot send e2e " +
    			"message when the network is not healthy")
    	}
    
    	return m.message.SendE2E(msg, e2eP, stop)
    }