mirror of
https://github.com/portainer/portainer.git
synced 2025-07-23 15:29:42 +02:00
fix: review snapshot and post init migration logic (#158)
This commit is contained in:
parent
07d1eedae3
commit
20e3d3a15b
5 changed files with 206 additions and 11 deletions
|
@ -11,6 +11,7 @@ import (
|
||||||
"github.com/portainer/portainer/api/internal/endpointutils"
|
"github.com/portainer/portainer/api/internal/endpointutils"
|
||||||
"github.com/portainer/portainer/api/kubernetes/cli"
|
"github.com/portainer/portainer/api/kubernetes/cli"
|
||||||
"github.com/portainer/portainer/api/pendingactions/actions"
|
"github.com/portainer/portainer/api/pendingactions/actions"
|
||||||
|
"github.com/portainer/portainer/pkg/endpoints"
|
||||||
|
|
||||||
"github.com/rs/zerolog/log"
|
"github.com/rs/zerolog/log"
|
||||||
)
|
)
|
||||||
|
@ -49,17 +50,29 @@ func (postInitMigrator *PostInitMigrator) PostInitMigrate() error {
|
||||||
|
|
||||||
for _, environment := range environments {
|
for _, environment := range environments {
|
||||||
// edge environments will run after the server starts, in pending actions
|
// edge environments will run after the server starts, in pending actions
|
||||||
if endpointutils.IsEdgeEndpoint(&environment) {
|
if endpoints.IsEdgeEndpoint(&environment) {
|
||||||
log.Info().Msgf("Adding pending action 'PostInitMigrateEnvironment' for environment %d", environment.ID)
|
// Skip edge environments that do not have direct connectivity
|
||||||
err = postInitMigrator.createPostInitMigrationPendingAction(environment.ID)
|
if !endpoints.HasDirectConnectivity(&environment) {
|
||||||
if err != nil {
|
continue
|
||||||
log.Error().Err(err).Msgf("Error creating pending action for environment %d", environment.ID)
|
}
|
||||||
|
|
||||||
|
log.Info().
|
||||||
|
Int("endpoint_id", int(environment.ID)).
|
||||||
|
Msg("adding pending action 'PostInitMigrateEnvironment' for environment")
|
||||||
|
|
||||||
|
if err := postInitMigrator.createPostInitMigrationPendingAction(environment.ID); err != nil {
|
||||||
|
log.Error().
|
||||||
|
Err(err).
|
||||||
|
Int("endpoint_id", int(environment.ID)).
|
||||||
|
Msg("error creating pending action for environment")
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// non-edge environments will run before the server starts.
|
// Non-edge environments will run before the server starts.
|
||||||
err = postInitMigrator.MigrateEnvironment(&environment)
|
if err := postInitMigrator.MigrateEnvironment(&environment); err != nil {
|
||||||
if err != nil {
|
log.Error().
|
||||||
log.Error().Err(err).Msgf("Error running post-init migrations for non-edge environment %d", environment.ID)
|
Err(err).
|
||||||
|
Int("endpoint_id", int(environment.ID)).
|
||||||
|
Msg("error running post-init migrations for non-edge environment")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,8 @@ import (
|
||||||
log "github.com/rs/zerolog/log"
|
log "github.com/rs/zerolog/log"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// TODO: this file should be migrated to package/server-ce/pkg/endpoints
|
||||||
|
|
||||||
// IsLocalEndpoint returns true if this is a local environment(endpoint)
|
// IsLocalEndpoint returns true if this is a local environment(endpoint)
|
||||||
func IsLocalEndpoint(endpoint *portainer.Endpoint) bool {
|
func IsLocalEndpoint(endpoint *portainer.Endpoint) bool {
|
||||||
return strings.HasPrefix(endpoint.URL, "unix://") ||
|
return strings.HasPrefix(endpoint.URL, "unix://") ||
|
||||||
|
|
|
@ -10,8 +10,8 @@ import (
|
||||||
"github.com/portainer/portainer/api/agent"
|
"github.com/portainer/portainer/api/agent"
|
||||||
"github.com/portainer/portainer/api/crypto"
|
"github.com/portainer/portainer/api/crypto"
|
||||||
"github.com/portainer/portainer/api/dataservices"
|
"github.com/portainer/portainer/api/dataservices"
|
||||||
"github.com/portainer/portainer/api/internal/endpointutils"
|
|
||||||
"github.com/portainer/portainer/api/pendingactions"
|
"github.com/portainer/portainer/api/pendingactions"
|
||||||
|
endpointsutils "github.com/portainer/portainer/pkg/endpoints"
|
||||||
|
|
||||||
"github.com/rs/zerolog/log"
|
"github.com/rs/zerolog/log"
|
||||||
)
|
)
|
||||||
|
@ -64,7 +64,7 @@ func NewBackgroundSnapshotter(dataStore dataservices.DataStore, tunnelService po
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, e := range endpoints {
|
for _, e := range endpoints {
|
||||||
if !endpointutils.IsEdgeEndpoint(&e) || e.Edge.AsyncMode || !e.UserTrusted {
|
if !endpointsutils.HasDirectConnectivity(&e) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
20
pkg/endpoints/utils.go
Normal file
20
pkg/endpoints/utils.go
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
package endpoints
|
||||||
|
|
||||||
|
import portainer "github.com/portainer/portainer/api"
|
||||||
|
|
||||||
|
// IsEdgeEndpoint returns true if this is an Edge endpoint
|
||||||
|
func IsEdgeEndpoint(endpoint *portainer.Endpoint) bool {
|
||||||
|
return endpoint.Type == portainer.EdgeAgentOnDockerEnvironment || endpoint.Type == portainer.EdgeAgentOnKubernetesEnvironment
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsAssociatedEdgeEndpoint returns true if the environment is an Edge environment
|
||||||
|
// and has a set EdgeID and UserTrusted is true.
|
||||||
|
func IsAssociatedEdgeEndpoint(endpoint *portainer.Endpoint) bool {
|
||||||
|
return IsEdgeEndpoint(endpoint) && endpoint.EdgeID != "" && endpoint.UserTrusted
|
||||||
|
}
|
||||||
|
|
||||||
|
// HasDirectConnectivity returns true if the environment is a non-Edge environment
|
||||||
|
// or is an associated Edge environment that is not in async mode.
|
||||||
|
func HasDirectConnectivity(endpoint *portainer.Endpoint) bool {
|
||||||
|
return !IsEdgeEndpoint(endpoint) || (IsAssociatedEdgeEndpoint(endpoint) && !endpoint.Edge.AsyncMode)
|
||||||
|
}
|
160
pkg/endpoints/utils_test.go
Normal file
160
pkg/endpoints/utils_test.go
Normal file
|
@ -0,0 +1,160 @@
|
||||||
|
package endpoints
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
portainer "github.com/portainer/portainer/api"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestIsEdgeEndpoint(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
endpoint *portainer.Endpoint
|
||||||
|
expected bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "EdgeAgentOnDockerEnvironment",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "EdgeAgentOnKubernetesEnvironment",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnKubernetesEnvironment,
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "NonEdgeEnvironment",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.DockerEnvironment,
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
result := IsEdgeEndpoint(tt.endpoint)
|
||||||
|
assert.Equal(t, tt.expected, result)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestIsAssociatedEdgeEndpoint(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
endpoint *portainer.Endpoint
|
||||||
|
expected bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "AssociatedEdgeEndpoint",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
EdgeID: "some-edge-id",
|
||||||
|
UserTrusted: true,
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "NonAssociatedEdgeEndpoint",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
EdgeID: "",
|
||||||
|
UserTrusted: true,
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "EdgeEndpointInWaitingRoom",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
EdgeID: "some-edge-id",
|
||||||
|
UserTrusted: false,
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "NonEdgeEnvironment",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.DockerEnvironment,
|
||||||
|
EdgeID: "some-edge-id",
|
||||||
|
UserTrusted: true,
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
result := IsAssociatedEdgeEndpoint(tt.endpoint)
|
||||||
|
assert.Equal(t, tt.expected, result)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHasDirectConnectivity(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
endpoint *portainer.Endpoint
|
||||||
|
expected bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "NonEdgeEnvironment",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.DockerEnvironment,
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "AssociatedEdgeEndpoint",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
EdgeID: "some-edge-id",
|
||||||
|
UserTrusted: true,
|
||||||
|
Edge: portainer.EnvironmentEdgeSettings{AsyncMode: false},
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "AssociatedAsyncEdgeEndpoint",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
EdgeID: "some-edge-id",
|
||||||
|
UserTrusted: true,
|
||||||
|
Edge: portainer.EnvironmentEdgeSettings{AsyncMode: true},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "EdgeEndpointInWaitingRoom",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
EdgeID: "some-edge-id",
|
||||||
|
UserTrusted: false,
|
||||||
|
Edge: portainer.EnvironmentEdgeSettings{AsyncMode: false},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "AsyncEdgeEndpointInWaitingRoom",
|
||||||
|
endpoint: &portainer.Endpoint{
|
||||||
|
Type: portainer.EdgeAgentOnDockerEnvironment,
|
||||||
|
EdgeID: "some-edge-id",
|
||||||
|
UserTrusted: false,
|
||||||
|
Edge: portainer.EnvironmentEdgeSettings{AsyncMode: true},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
result := HasDirectConnectivity(tt.endpoint)
|
||||||
|
assert.Equal(t, tt.expected, result)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue