Files
cloudpods/pkg/compute/tasks/container/container_start_task.go

108 lines
3.9 KiB
Go

// Copyright 2019 Yunion
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package container
import (
"context"
"yunion.io/x/jsonutils"
"yunion.io/x/pkg/errors"
api "yunion.io/x/onecloud/pkg/apis/compute"
"yunion.io/x/onecloud/pkg/cloudcommon/db"
"yunion.io/x/onecloud/pkg/cloudcommon/db/taskman"
"yunion.io/x/onecloud/pkg/compute/models"
)
type ContainerStartTask struct {
ContainerBaseTask
}
func init() {
taskman.RegisterTask(ContainerStartTask{})
}
func (t *ContainerStartTask) OnInit(ctx context.Context, obj db.IStandaloneModel, body jsonutils.JSONObject) {
ctr := obj.(*models.SContainer)
if err := t.startCacheImages(ctx, ctr); err != nil {
t.OnStartedFailed(ctx, ctr, jsonutils.NewString(err.Error()))
}
}
func (t *ContainerStartTask) startCacheImages(ctx context.Context, ctr *models.SContainer) error {
t.SetStage("OnCacheImagesComplete", nil)
input, err := t.GetContainerCacheImagesInput(ctr)
if err != nil {
return errors.Wrap(err, "GetContainerCacheImagesInput")
}
if len(input.Images) == 0 {
t.OnCacheImagesComplete(ctx, ctr, nil)
return nil
}
return ctr.StartCacheImagesTask(ctx, t.GetUserCred(), input, t.GetTaskId())
}
func (t *ContainerStartTask) OnCacheImagesComplete(ctx context.Context, ctr *models.SContainer, data jsonutils.JSONObject) {
t.requestSyncConf(ctx, ctr)
}
func (t *ContainerStartTask) OnCacheImagesCompleteFailed(ctx context.Context, ctr *models.SContainer, data jsonutils.JSONObject) {
t.OnStartedFailed(ctx, ctr, jsonutils.NewString(data.String()))
}
func (t *ContainerStartTask) requestSyncConf(ctx context.Context, container *models.SContainer) {
// sync configuration to make server of host to refresh desc file
t.SetStage("OnSyncConf", nil)
if err := container.GetPod().StartSyncTaskWithoutSyncstatus(ctx, t.GetUserCred(), false, t.GetTaskId()); err != nil {
t.OnSyncConfFailed(ctx, container, jsonutils.NewString(err.Error()))
return
}
}
func (t *ContainerStartTask) OnSyncConf(ctx context.Context, container *models.SContainer, data jsonutils.JSONObject) {
t.requestStart(ctx, container)
}
func (t *ContainerStartTask) OnSyncConfFailed(ctx context.Context, container *models.SContainer, reason jsonutils.JSONObject) {
container.SetStatus(ctx, t.GetUserCred(), api.CONTAINER_STATUS_SYNC_CONF_FAILED, reason.String())
t.SetStageFailed(ctx, reason)
}
func (t *ContainerStartTask) requestStart(ctx context.Context, container *models.SContainer) {
t.SetStage("OnStarted", nil)
if err := t.GetPodDriver().RequestStartContainer(ctx, t.GetUserCred(), t); err != nil {
t.OnStartedFailed(ctx, container, jsonutils.NewString(err.Error()))
return
}
}
func (t *ContainerStartTask) OnStarted(ctx context.Context, container *models.SContainer, data jsonutils.JSONObject) {
t.SetStage("OnSyncStatus", nil)
container.StartSyncStatusTask(ctx, t.GetUserCred(), t.GetTaskId())
}
func (t *ContainerStartTask) OnStartedFailed(ctx context.Context, container *models.SContainer, reason jsonutils.JSONObject) {
container.SetStatus(ctx, t.GetUserCred(), api.CONTAINER_STATUS_START_FAILED, reason.String())
t.SetStageFailed(ctx, reason)
}
func (t *ContainerStartTask) OnSyncStatus(ctx context.Context, container *models.SContainer, data jsonutils.JSONObject) {
t.SetStageComplete(ctx, nil)
}
func (t *ContainerStartTask) OnSyncStatusFailed(ctx context.Context, container *models.SContainer, reason jsonutils.JSONObject) {
t.SetStageFailed(ctx, reason)
}