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

service.go

Blame
  • service.go 2.72 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 groupChat
    
    import (
    	"github.com/pkg/errors"
    	"gitlab.com/elixxir/client/catalog"
    	"gitlab.com/elixxir/client/cmix/message"
    	gs "gitlab.com/elixxir/client/groupChat/groupStore"
    	"gitlab.com/xx_network/primitives/id"
    )
    
    // Error messages.
    const (
    	// manager.AddService
    	errServiceExists = "service with tag %q already exists"
    
    	// manager.RemoveService
    	errServiceNotExists = "service with tag %q does not exist"
    )
    
    func (m *manager) AddService(tag string, p Processor) error {
    	m.servicesMux.Lock()
    	defer m.servicesMux.Unlock()
    
    	if _, exists := m.services[tag]; exists {
    		// Return an error if the service already exists
    		return errors.Errorf(errServiceExists, tag)
    	} else {
    		// Add the service to the list
    		m.services[tag] = p
    	}
    
    	// Add a service for every group
    	for _, g := range m.gs.Groups() {
    		newService := makeService(g.ID, tag)
    		m.getCMix().AddService(m.getReceptionIdentity().ID, newService,
    			&receptionProcessor{m, g, p})
    	}
    
    	return nil
    }
    
    func (m *manager) RemoveService(tag string) error {
    	m.servicesMux.Lock()
    	defer m.servicesMux.Unlock()
    
    	// Delete the service from the list
    	oldProcess, exists := m.services[tag]
    	if exists {
    		return errors.Errorf(errServiceNotExists, tag)
    	} else {
    		delete(m.services, tag)
    	}
    
    	// Delete service for every group
    	for _, g := range m.gs.Groups() {
    		toDelete := makeService(g.ID, tag)
    		m.getCMix().DeleteService(m.getReceptionIdentity().ID, toDelete,
    			&receptionProcessor{m, g, oldProcess})
    	}
    
    	return nil
    }
    
    // addAllServices adds every service for the given group.
    func (m *manager) addAllServices(g gs.Group) {
    	for tag, p := range m.services {
    		newService := makeService(g.ID, tag)
    		m.getCMix().AddService(m.getReceptionIdentity().ID, newService,
    			&receptionProcessor{m, g, p})
    	}
    }
    
    // deleteAllServices deletes every service for the given group.
    func (m *manager) deleteAllServices(groupID *id.ID) {
    	for tag := range m.services {
    		toDelete := makeService(groupID, tag)
    		m.getCMix().DeleteService(m.getReceptionIdentity().ID, toDelete, nil)
    	}
    }
    
    func makeService(groupID *id.ID, tag string) message.Service {
    	return message.Service{
    		Identifier: groupID[:],
    		Tag:        makeServiceTag(tag),
    		Metadata:   groupID[:],
    	}
    }
    
    func makeServiceTag(tag string) string {
    	return catalog.Group + "-" + tag
    }