package ncloud import ( "context" "errors" "fmt" "time" "github.com/NaverCloudPlatform/ncloud-sdk-go-v2/services/server" "github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer-plugin-sdk/multistep" ) type StepCreateServerImage struct { Conn *NcloudAPIClient CreateServerImage func(serverInstanceNo string) (*server.MemberServerImage, error) Say func(message string) Error func(e error) Config *Config } func NewStepCreateServerImage(conn *NcloudAPIClient, ui packer.Ui, config *Config) *StepCreateServerImage { var step = &StepCreateServerImage{ Conn: conn, Say: func(message string) { ui.Say(message) }, Error: func(e error) { ui.Error(e.Error()) }, Config: config, } step.CreateServerImage = step.createServerImage return step } func (s *StepCreateServerImage) createServerImage(serverInstanceNo string) (*server.MemberServerImage, error) { // Can't create server image when status of server instance is stopping (not stopped) if err := waiterServerInstanceStatus(s.Conn, serverInstanceNo, "NSTOP", 1*time.Minute); err != nil { return nil, err } reqParams := new(server.CreateMemberServerImageRequest) reqParams.MemberServerImageName = &s.Config.ServerImageName reqParams.MemberServerImageDescription = &s.Config.ServerImageDescription reqParams.ServerInstanceNo = &serverInstanceNo memberServerImageList, err := s.Conn.server.V2Api.CreateMemberServerImage(reqParams) if err != nil { return nil, err } serverImage := memberServerImageList.MemberServerImageList[0] s.Say(fmt.Sprintf("Server Image[%s:%s] is creating...", *serverImage.MemberServerImageName, *serverImage.MemberServerImageNo)) if err := waiterMemberServerImageStatus(s.Conn, *serverImage.MemberServerImageNo, "CREAT", 6*time.Hour); err != nil { return nil, errors.New("TIMEOUT : Server Image is not created") } s.Say(fmt.Sprintf("Server Image[%s:%s] is created", *serverImage.MemberServerImageName, *serverImage.MemberServerImageNo)) return serverImage, nil } func (s *StepCreateServerImage) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction { s.Say("Create Server Image") serverInstanceNo := state.Get("InstanceNo").(string) serverImage, err := s.CreateServerImage(serverInstanceNo) if err == nil { state.Put("memberServerImage", serverImage) } return processStepResult(err, s.Error, state) } func (*StepCreateServerImage) Cleanup(multistep.StateBag) { }