Skip to content
Snippets Groups Projects
Select Git revision
  • abc57b7293a39f5e7519118a09e05e1691b4538a
  • 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

listener.go

Blame
  • listener.go 1.58 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 (
    	jww "github.com/spf13/jwalterweatherman"
    	"gitlab.com/elixxir/client/e2e/receive"
    )
    
    // Error messages.
    const (
    	// listener.Hear
    	errNewReceivedTransfer = "[FT] Failed to add new received transfer: %+v"
    )
    
    // Name of listener (used for debugging)
    const listenerName = "NewFileTransferListener-Connection"
    
    // listener waits for a message indicating a new file transfer is starting.
    // Adheres to the receive.Listener interface.
    type listener struct {
    	m *Wrapper
    }
    
    // Hear is called when a new file transfer is received. It creates a new
    // internal received file transfer and starts waiting to receive file part
    // messages.
    func (l *listener) Hear(msg receive.Message) {
    	// Add new transfer to start receiving parts
    	tid, info, err := l.m.ft.HandleIncomingTransfer(msg.Payload, nil, 0)
    	if err != nil {
    		jww.ERROR.Printf(errNewReceivedTransfer, err)
    		return
    	}
    
    	// Call the reception callback
    	go l.m.receiveCB(
    		tid, info.FileName, info.FileType, msg.Sender, info.Size, info.Preview)
    }
    
    // Name returns a name used for debugging.
    func (l *listener) Name() string {
    	return listenerName
    }