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

manager_test.go

Blame
  • params.go 2.61 KiB
    ////////////////////////////////////////////////////////////////////////////////
    // Copyright © 2022 xx foundation                                             //
    //                                                                            //
    // Use of this source code is governed by a license that can be found in the  //
    // LICENSE file.                                                              //
    ////////////////////////////////////////////////////////////////////////////////
    
    package single
    
    import (
    	"encoding/json"
    	"gitlab.com/elixxir/client/cmix"
    	"time"
    )
    
    // Default values.
    const (
    	defaultRequestTimeout      = 30 * time.Second
    	defaultMaxResponseMessages = 255
    )
    
    // RequestParams contains configurable parameters for sending a single-use
    // request message.
    type RequestParams struct {
    	// Timeout is the duration to wait before timing out while sending a request
    	Timeout time.Duration
    
    	// MaxResponseMessages is the maximum number of messages allowed in the
    	// response to the request
    	MaxResponseMessages uint8
    
    	// CmixParams is the parameters used in sending a cMix message
    	CmixParams cmix.CMIXParams
    }
    
    // requestParamsDisk will be the marshal-able and umarshal-able object.
    type requestParamsDisk struct {
    	Timeout             time.Duration
    	MaxResponseMessages uint8
    	CmixParams          cmix.CMIXParams
    }
    
    // GetDefaultRequestParams returns a RequestParams with the default
    // configuration.
    func GetDefaultRequestParams() RequestParams {
    	return RequestParams{
    		Timeout:             defaultRequestTimeout,
    		MaxResponseMessages: defaultMaxResponseMessages,
    		CmixParams:          cmix.GetDefaultCMIXParams(),
    	}
    }
    
    // GetParameters returns the default network parameters, or override with given
    // parameters, if set.
    func GetParameters(params string) (RequestParams, error) {
    	p := GetDefaultRequestParams()
    	if len(params) > 0 {
    		err := json.Unmarshal([]byte(params), &p)
    		if err != nil {
    			return RequestParams{}, err
    		}
    	}
    	return p, nil
    }
    
    // MarshalJSON adheres to the json.Marshaler interface.
    func (rp RequestParams) MarshalJSON() ([]byte, error) {
    	pDisk := requestParamsDisk{
    		Timeout:             rp.Timeout,
    		MaxResponseMessages: rp.MaxResponseMessages,
    		CmixParams:          rp.CmixParams,
    	}
    
    	return json.Marshal(&pDisk)
    
    }
    
    // UnmarshalJSON adheres to the json.Unmarshaler interface.
    func (rp *RequestParams) UnmarshalJSON(data []byte) error {
    	pDisk := requestParamsDisk{}
    	err := json.Unmarshal(data, &pDisk)
    	if err != nil {
    		return err
    	}
    
    	*rp = RequestParams{
    		Timeout:             pDisk.Timeout,
    		MaxResponseMessages: pDisk.MaxResponseMessages,
    		CmixParams:          pDisk.CmixParams,
    	}
    
    	return nil
    }