File: acl_bridge.go

package info (click to toggle)
incus 6.0.5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 24,392 kB
  • sloc: sh: 16,313; ansic: 3,121; python: 457; makefile: 337; ruby: 51; sql: 50; lisp: 6
file content (38 lines) | stat: -rw-r--r-- 1,094 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
package acl

import (
	"fmt"

	"github.com/lxc/incus/v6/internal/server/instance"
	"github.com/lxc/incus/v6/internal/server/state"
	"github.com/lxc/incus/v6/shared/logger"
)

// BridgeUpdateACLs forces the update of all NIC devices who have the changed ACL applied.
func BridgeUpdateACLs(s *state.State, l logger.Logger, aclProjectName string, aclNetDevices map[string]NetworkACLUsage) error {
	// Update of the bridge NICs affected by the ACL change
	for _, aclNetDevice := range aclNetDevices {
		inst, err := instance.LoadByProjectAndName(s, aclProjectName, aclNetDevice.InstanceName)
		if err != nil {
			return err
		}

		// Skip remote instances.
		if inst.Location() != "" && inst.Location() != s.ServerName {
			continue
		}

		// Skip stopped instances
		if !inst.IsRunning() {
			continue
		}

		// Trigger the device update.
		err = inst.ReloadDevice(aclNetDevice.DeviceName)
		if err != nil {
			return fmt.Errorf("Failed to trigger device update for device %q of instance %q in project %q: %w", aclNetDevice.DeviceName, inst.Name(), inst.Project().Name, err)
		}
	}

	return nil
}